

翻訳は機械翻訳により提供されています。提供された翻訳内容と英語版の間で齟齬、不一致または矛盾がある場合、英語版が優先します。

# X-Ray SDK for .NET を使用してセグメントに注釈とメタデータを追加する
<a name="xray-sdk-dotnet-segment"></a>

**注記**  
X-Ray SDK/デーモンメンテナンス通知 – 2026 年 2 月 25 日、 AWS X-Ray SDKsデーモンはメンテナンスモードに移行します。 AWS では、X-Ray SDK とデーモンのリリースがセキュリティの問題にのみ対処するように制限されます。サポートタイムラインの詳細については、「[X-Ray SDK とデーモンのサポートタイムライン](xray-sdk-daemon-timeline.md)」を参照してください。OpenTelemetry に移行することをお勧めします。OpenTelemetry への移行の詳細については、「[X-Ray による計装から OpenTelemetry による計装への移行](https://docs.aws.amazon.com/xray/latest/devguide/xray-sdk-migration.html)」を参照してください。

リクエスト、環境、または注釈やメタデータを使用するアプリケーションに関する追加情報を記録できます。X-Ray SDK が作成するセグメントまたは作成するカスタムサブセグメントに、注釈およびメタデータを追加できます。

**注釈**は文字列、数値、またはブール値を使用したキーと値のペアです。注釈は、[フィルタ式](xray-console-filters.md)用にインデックス付けされます。注釈を使用して、コンソールでトレースをグループ化するため、または[https://docs.aws.amazon.com/xray/latest/api/API_GetTraceSummaries.html](https://docs.aws.amazon.com/xray/latest/api/API_GetTraceSummaries.html) API を呼び出すときに使用するデータを記録します。

**メタデータ**は、オブジェクトとリストを含む、任意のタイプの値を持つことができるキーバリューのペアですが、フィルタ式に使用するためにインデックスは作成されません。メタデータを使用してトレースに保存する追加のデータを記録しますが、トレースの検索用に使用する必要はありません。

**Topics**
+ [X-Ray SDK を使用して.NET の注釈を記録する](#xray-sdk-dotnet-segment-annotations)
+ [X-Ray SDK for .NET](#xray-sdk-dotnet-segment-metadata)

## X-Ray SDK を使用して.NET の注釈を記録する
<a name="xray-sdk-dotnet-segment-annotations"></a>

注釈を使用して、検索用にインデックスを作成するセグメントまたはサブセグメントに情報を記録します。

X-Ray のすべての注釈には以下が必要です。

**注釈の要件**
+ **キー** – X-Ray 注釈のキーには最大 500 文字の英数字を使用できます。スペースまたはドットやピリオド (.) 以外の記号は使用できません。
+ **値** – X-Ray 注釈の値には最大 1,000 の Unicode 文字を使用できます。
+ **注釈**の数 – トレースごとに最大 50 の注釈を使用できます。

**AWS Lambda 関数の外部に注釈を記録するには**

1. `AWSXRayRecorder` のインスタンスを取得します。

   ```
   using [Amazon.XRay.Recorder.Core](https://docs.aws.amazon.com/xray-sdk-for-dotnet/latest/reference/html/N_Amazon_XRay_Recorder_Core.htm);
   ...
   AWSXRayRecorder recorder = AWSXRayRecorder.Instance;
   ```

1. 文字列キー、およびブール値、Int32、Int64、Double、文字列値を使用して `addAnnotation` を呼び出します。

   ```
   recorder.AddAnnotation("mykey", "my value");
   ```

   次の例は、ドット、ブール値、数値、または文字列値を含む文字列キーを使用して `putAnnotation` を呼び出す方法を示しています。

   ```
   document.putAnnotation("testkey.test", "my value");
   ```

**AWS Lambda 関数内の注釈を記録するには**

Lambda ランタイム環境では Lambda 関数内のセグメントとサブセグメントの両方が管理されます。Lambda 関数内のセグメントまたはサブセグメントに注釈を追加する場合は、以下の内容を実行する必要があります。

1. Lambda 関数内にセグメントまたはサブセグメントを作成します。

1. セグメントまたはサブセグメントに注釈を追加します。

1. セグメントまたはサブセグメントを終了します。

次のコード例は、Lambda 関数内のサブセグメントに注釈を追加する方法を示しています。

```
#Create the subsegment
AWSXRayRecorder.Instance.BeginSubsegment("custom method");
#Add an annotation
AWSXRayRecorder.Instance.AddAnnotation("My", "Annotation");
try
{
  YourProcess(); #Your function
}
catch (Exception e)
{
  AWSXRayRecorder.Instance.AddException(e);
}
finally #End the subsegment
{
  AWSXRayRecorder.Instance.EndSubsegment();
}
```

X-Ray SDK は、セグメントドキュメントの `annotations` オブジェクトにキーと値のペアとして、注釈を記録します。同じキーで `addAnnotation` を 2 回呼び出すと、同じセグメントまたはサブセグメントに以前記録された値は上書きされます。

特定の値を持つ注釈のあるトレースを見つけるには、`annotation[key]`フィルタ式[の ](xray-console-filters.md) キーワードを使用します。

## X-Ray SDK for .NET
<a name="xray-sdk-dotnet-segment-metadata"></a>

メタデータを使用して、検索内でインデックスを使用する必要がないセグメントまたはサブセグメントに情報を記録します。メタデータ値は、文字列、数値、ブール値、または JSON オブジェクトや JSON 配列にシリアル化できるその他の任意のオブジェクトになります。

**メタデータを記録するには**

1. 次のコード例に示すように、`AWSXRayRecorder` のインスタンスを取得します。

   ```
   using [Amazon.XRay.Recorder.Core](https://docs.aws.amazon.com/xray-sdk-for-dotnet/latest/reference/html/N_Amazon_XRay_Recorder_Core.htm);
   ...
   AWSXRayRecorder recorder = AWSXRayRecorder.Instance;
   ```

1. 次のコード例に示すように、文字列名前空間、文字列キー、およびオブジェクト値を使用して `AddMetadata` を呼び出します。

   ```
   recorder.AddMetadata("my namespace", "my key", "my value");
   ```

   次のコード例に示すように、キーと値のペアのみを使用して `AddMetadata` オペレーションを呼び出すこともできます。

   ```
   recorder.AddMetadata("my key", "my value");
   ```

名前空間の値を指定しない場合、X-Ray SDK は `default` を使用します。同じキーで `AddMetadata` を 2 回呼び出すと、同じセグメントまたはサブセグメントに以前記録された値は上書きされます。