4. 機密データの秘匿化
4.3 Redaction Processorのテスト
redaction プロセッサは、テレメトリーデータからどの属性と値を許可または削除するかを正確に制御できます。
この演習では、Agent がエクスポートする前に、Spanデータの user.visa と user.mastercard の値を秘匿化します。
Exercise
Gatewayを起動する:Gateway terminal ウィンドウで Gateway を起動します。
../otelcol --config=gateway.yamlredaction/redact プロセッサを有効にする:Agent terminal ウィンドウで、agent.yaml を編集して前の演習で追加した # を削除します。
traces:
receivers:
- otlp
processors:
- memory_limiter
- attributes/update # Update, hash, and remove attributes
- redaction/redact # Redact sensitive fields using regex
- resourcedetection
- resource/add_mode
- batch
exporters:
- debug
- file
- otlphttpAgentを起動する:Agent terminal ウィンドウで Agent を起動します。
../otelcol --config=agent.yamlLoad Generatorを起動する:Loadgen terminal ウィンドウで loadgen を起動します
../loadgen -count 1デバッグ出力を確認する:Agent と Gateway の両方で、user.visa と user.mastercard の値が更新されていることを確認します。user.amex 属性の値は、blocked_values に一致する正規表現パターンが追加されていないため、秘匿化されていないことに注意してください。
-> user.name: Str(George Lucas)
-> user.phone_number: Str(UNKNOWN NUMBER)
-> user.email: Str(62d5e03d8fd5808e77aee5ebbd90cf7627a470ae0be9ffd10e8025a4ad0e1287)
-> payment.amount: Double(69.71)
-> user.visa: Str(****)
-> user.amex: Str(3782 822463 10005)
-> user.mastercard: Str(****)
-> redaction.masked.keys: Str(user.mastercard,user.visa)
-> redaction.masked.count: Int(2) -> user.name: Str(George Lucas)
-> user.phone_number: Str(+1555-867-5309)
-> user.email: Str(george@deathstar.email)
-> user.password: Str(LOTR>StarWars1-2-3)
-> user.visa: Str(4111 1111 1111 1111)
-> user.amex: Str(3782 822463 10005)
-> user.mastercard: Str(5555 5555 5555 4444)
-> payment.amount: Double(65.54)Note
redaction プロセッサに summary:debug を含めると、デバッグ出力に、どの一致するキー値が秘匿化されたか、およびマスクされた値の数に関するサマリー情報が含まれます。
-> redaction.masked.keys: Str(user.mastercard,user.visa)
-> redaction.masked.count: Int(2)ファイル出力を確認する:jq を使用して、gateway-traces.out で user.visa と user.mastercard が更新されていることを検証します。
jq '.resourceSpans[].scopeSpans[].spans[].attributes[] | select(.key == "user.visa" or .key == "user.mastercard" or .key == "user.amex") | {key: .key, value: .value.stringValue}' ./gateway-traces.outblocked_values に一致する正規表現パターンが追加されていないため、user.amex は秘匿化されていないことに注意してください
{
"key": "user.visa",
"value": "****"
}
{
"key": "user.amex",
"value": "3782 822463 10005"
}
{
"key": "user.mastercard",
"value": "****"
}これらは、attributes と redaction プロセッサを設定して機密データを保護する方法のほんの一例です。
Info
Agent と Gateway プロセスを、それぞれのターミナルで Ctrl-C を押して停止してください。
