Semantic conventions for AWS SDK

Status: Experimental

This document defines semantic conventions to apply when instrumenting the AWS SDK. They map request or response parameters in AWS SDK API calls to attributes on a Span. The conventions have been collected over time based on feedback from AWS users of tracing and will continue to increase as new interesting conventions are found.

Some descriptions are also provided for populating general OpenTelemetry semantic conventions based on these APIs.

Common Attributes

The span name MUST be of the format Service.Operation as per the AWS HTTP API, e.g., DynamoDB.GetItem, S3.ListBuckets. This is equivalent to concatenating rpc.service and rpc.method with . and consistent with the naming guidelines for RPC client spans.

AttributeTypeDescriptionExamplesRequirement Level
aws.request_idstringThe AWS request ID as returned in the response headers x-amz-request-id or x-amz-requestid.79b9da39-b7ae-508a-a6bc-864b2829c622; C9ER4AJX75574TDJRecommended
rpc.methodstringThe name of the operation corresponding to the request, as returned by the AWS SDK [1]GetItem; PutItemRecommended
rpc.servicestringThe name of the service to which a request is made, as returned by the AWS SDK. [2]DynamoDB; S3Recommended
rpc.systemstringThe value aws-api.aws-apiRequired

[1]: This is the logical name of the method from the RPC interface perspective, which can be different from the name of any implementing method/function. The code.function attribute may be used to store the latter (e.g., method actually executing the call on the server side, RPC client stub method on the client side).

[2]: This is the logical name of the service from the RPC interface perspective, which can be different from the name of any implementing class. The code.namespace attribute may be used to store the latter (despite the attribute name, it may include a class name; e.g., class with method actually executing the call on the server side, RPC client stub class on the client side).

DynamoDB

Common Attributes

These attributes are filled in for all DynamoDB request types.

AttributeTypeDescriptionExamplesRequirement Level
db.systemstringThe value dynamodb.dynamodbRequired

DynamoDB.BatchGetItem

AttributeTypeDescriptionExamplesRequirement Level
aws.dynamodb.consumed_capacitystring[]The JSON-serialized value of each item in the ConsumedCapacity response field.[{ "CapacityUnits": number, "GlobalSecondaryIndexes": { "string" : { "CapacityUnits": number, "ReadCapacityUnits": number, "WriteCapacityUnits": number } }, "LocalSecondaryIndexes": { "string" : { "CapacityUnits": number, "ReadCapacityUnits": number, "WriteCapacityUnits": number } }, "ReadCapacityUnits": number, "Table": { "CapacityUnits": number, "ReadCapacityUnits": number, "WriteCapacityUnits": number }, "TableName": "string", "WriteCapacityUnits": number }]Recommended
aws.dynamodb.table_namesstring[]The keys in the RequestItems object field.[Users, Cats]Recommended

DynamoDB.BatchWriteItem

AttributeTypeDescriptionExamplesRequirement Level
aws.dynamodb.consumed_capacitystring[]The JSON-serialized value of each item in the ConsumedCapacity response field.[{ "CapacityUnits": number, "GlobalSecondaryIndexes": { "string" : { "CapacityUnits": number, "ReadCapacityUnits": number, "WriteCapacityUnits": number } }, "LocalSecondaryIndexes": { "string" : { "CapacityUnits": number, "ReadCapacityUnits": number, "WriteCapacityUnits": number } }, "ReadCapacityUnits": number, "Table": { "CapacityUnits": number, "ReadCapacityUnits": number, "WriteCapacityUnits": number }, "TableName": "string", "WriteCapacityUnits": number }]Recommended
aws.dynamodb.item_collection_metricsstringThe JSON-serialized value of the ItemCollectionMetrics response field.{ "string" : [ { "ItemCollectionKey": { "string" : { "B": blob, "BOOL": boolean, "BS": [ blob ], "L": [ "AttributeValue" ], "M": { "string" : "AttributeValue" }, "N": "string", "NS": [ "string" ], "NULL": boolean, "S": "string", "SS": [ "string" ] } }, "SizeEstimateRangeGB": [ number ] } ] }Recommended
aws.dynamodb.table_namesstring[]The keys in the RequestItems object field.[Users, Cats]Recommended

DynamoDB.CreateTable

AttributeTypeDescriptionExamplesRequirement Level
aws.dynamodb.global_secondary_indexesstring[]The JSON-serialized value of each item of the GlobalSecondaryIndexes request field[{ "IndexName": "string", "KeySchema": [ { "AttributeName": "string", "KeyType": "string" } ], "Projection": { "NonKeyAttributes": [ "string" ], "ProjectionType": "string" }, "ProvisionedThroughput": { "ReadCapacityUnits": number, "WriteCapacityUnits": number } }]Recommended
aws.dynamodb.local_secondary_indexesstring[]The JSON-serialized value of each item of the LocalSecondaryIndexes request field.[{ "IndexArn": "string", "IndexName": "string", "IndexSizeBytes": number, "ItemCount": number, "KeySchema": [ { "AttributeName": "string", "KeyType": "string" } ], "Projection": { "NonKeyAttributes": [ "string" ], "ProjectionType": "string" } }]Recommended
aws.dynamodb.consumed_capacitystring[]The JSON-serialized value of each item in the ConsumedCapacity response field.[{ "CapacityUnits": number, "GlobalSecondaryIndexes": { "string" : { "CapacityUnits": number, "ReadCapacityUnits": number, "WriteCapacityUnits": number } }, "LocalSecondaryIndexes": { "string" : { "CapacityUnits": number, "ReadCapacityUnits": number, "WriteCapacityUnits": number } }, "ReadCapacityUnits": number, "Table": { "CapacityUnits": number, "ReadCapacityUnits": number, "WriteCapacityUnits": number }, "TableName": "string", "WriteCapacityUnits": number }]Recommended
aws.dynamodb.item_collection_metricsstringThe JSON-serialized value of the ItemCollectionMetrics response field.{ "string" : [ { "ItemCollectionKey": { "string" : { "B": blob, "BOOL": boolean, "BS": [ blob ], "L": [ "AttributeValue" ], "M": { "string" : "AttributeValue" }, "N": "string", "NS": [ "string" ], "NULL": boolean, "S": "string", "SS": [ "string" ] } }, "SizeEstimateRangeGB": [ number ] } ] }Recommended
aws.dynamodb.provisioned_read_capacitydoubleThe value of the ProvisionedThroughput.ReadCapacityUnits request parameter.1.0; 2.0Recommended
aws.dynamodb.provisioned_write_capacitydoubleThe value of the ProvisionedThroughput.WriteCapacityUnits request parameter.1.0; 2.0Recommended
aws.dynamodb.table_namesstring[]A single-element array with the value of the TableName request parameter.[Users]Recommended

DynamoDB.DeleteItem

AttributeTypeDescriptionExamplesRequirement Level
aws.dynamodb.consumed_capacitystring[]The JSON-serialized value of each item in the ConsumedCapacity response field.[{ "CapacityUnits": number, "GlobalSecondaryIndexes": { "string" : { "CapacityUnits": number, "ReadCapacityUnits": number, "WriteCapacityUnits": number } }, "LocalSecondaryIndexes": { "string" : { "CapacityUnits": number, "ReadCapacityUnits": number, "WriteCapacityUnits": number } }, "ReadCapacityUnits": number, "Table": { "CapacityUnits": number, "ReadCapacityUnits": number, "WriteCapacityUnits": number }, "TableName": "string", "WriteCapacityUnits": number }]Recommended
aws.dynamodb.item_collection_metricsstringThe JSON-serialized value of the ItemCollectionMetrics response field.{ "string" : [ { "ItemCollectionKey": { "string" : { "B": blob, "BOOL": boolean, "BS": [ blob ], "L": [ "AttributeValue" ], "M": { "string" : "AttributeValue" }, "N": "string", "NS": [ "string" ], "NULL": boolean, "S": "string", "SS": [ "string" ] } }, "SizeEstimateRangeGB": [ number ] } ] }Recommended
aws.dynamodb.table_namesstring[]A single-element array with the value of the TableName request parameter.[Users]Recommended

DynamoDB.DeleteTable

AttributeTypeDescriptionExamplesRequirement Level
aws.dynamodb.table_namesstring[]A single-element array with the value of the TableName request parameter.[Users]Recommended

DynamoDB.DescribeTable

AttributeTypeDescriptionExamplesRequirement Level
aws.dynamodb.table_namesstring[]A single-element array with the value of the TableName request parameter.[Users]Recommended

DynamoDB.GetItem

AttributeTypeDescriptionExamplesRequirement Level
aws.dynamodb.consistent_readbooleanThe value of the ConsistentRead request parameter.Recommended
aws.dynamodb.consumed_capacitystring[]The JSON-serialized value of each item in the ConsumedCapacity response field.[{ "CapacityUnits": number, "GlobalSecondaryIndexes": { "string" : { "CapacityUnits": number, "ReadCapacityUnits": number, "WriteCapacityUnits": number } }, "LocalSecondaryIndexes": { "string" : { "CapacityUnits": number, "ReadCapacityUnits": number, "WriteCapacityUnits": number } }, "ReadCapacityUnits": number, "Table": { "CapacityUnits": number, "ReadCapacityUnits": number, "WriteCapacityUnits": number }, "TableName": "string", "WriteCapacityUnits": number }]Recommended
aws.dynamodb.projectionstringThe value of the ProjectionExpression request parameter.Title; Title, Price, Color; Title, Description, RelatedItems, ProductReviewsRecommended
aws.dynamodb.table_namesstring[]A single-element array with the value of the TableName request parameter.[Users]Recommended

DynamoDB.ListTables

AttributeTypeDescriptionExamplesRequirement Level
aws.dynamodb.exclusive_start_tablestringThe value of the ExclusiveStartTableName request parameter.Users; CatsTableRecommended
aws.dynamodb.table_countintThe the number of items in the TableNames response parameter.20Recommended
aws.dynamodb.limitintThe value of the Limit request parameter.10Recommended

DynamoDB.PutItem

AttributeTypeDescriptionExamplesRequirement Level
aws.dynamodb.consumed_capacitystring[]The JSON-serialized value of each item in the ConsumedCapacity response field.[{ "CapacityUnits": number, "GlobalSecondaryIndexes": { "string" : { "CapacityUnits": number, "ReadCapacityUnits": number, "WriteCapacityUnits": number } }, "LocalSecondaryIndexes": { "string" : { "CapacityUnits": number, "ReadCapacityUnits": number, "WriteCapacityUnits": number } }, "ReadCapacityUnits": number, "Table": { "CapacityUnits": number, "ReadCapacityUnits": number, "WriteCapacityUnits": number }, "TableName": "string", "WriteCapacityUnits": number }]Recommended
aws.dynamodb.item_collection_metricsstringThe JSON-serialized value of the ItemCollectionMetrics response field.{ "string" : [ { "ItemCollectionKey": { "string" : { "B": blob, "BOOL": boolean, "BS": [ blob ], "L": [ "AttributeValue" ], "M": { "string" : "AttributeValue" }, "N": "string", "NS": [ "string" ], "NULL": boolean, "S": "string", "SS": [ "string" ] } }, "SizeEstimateRangeGB": [ number ] } ] }Recommended
aws.dynamodb.table_namesstring[]The keys in the RequestItems object field.[Users, Cats]Recommended

DynamoDB.Query

AttributeTypeDescriptionExamplesRequirement Level
aws.dynamodb.scan_forwardbooleanThe value of the ScanIndexForward request parameter.Recommended
aws.dynamodb.attributes_to_getstring[]The value of the AttributesToGet request parameter.[lives, id]Recommended
aws.dynamodb.consistent_readbooleanThe value of the ConsistentRead request parameter.Recommended
aws.dynamodb.consumed_capacitystring[]The JSON-serialized value of each item in the ConsumedCapacity response field.[{ "CapacityUnits": number, "GlobalSecondaryIndexes": { "string" : { "CapacityUnits": number, "ReadCapacityUnits": number, "WriteCapacityUnits": number } }, "LocalSecondaryIndexes": { "string" : { "CapacityUnits": number, "ReadCapacityUnits": number, "WriteCapacityUnits": number } }, "ReadCapacityUnits": number, "Table": { "CapacityUnits": number, "ReadCapacityUnits": number, "WriteCapacityUnits": number }, "TableName": "string", "WriteCapacityUnits": number }]Recommended
aws.dynamodb.index_namestringThe value of the IndexName request parameter.name_to_groupRecommended
aws.dynamodb.limitintThe value of the Limit request parameter.10Recommended
aws.dynamodb.projectionstringThe value of the ProjectionExpression request parameter.Title; Title, Price, Color; Title, Description, RelatedItems, ProductReviewsRecommended
aws.dynamodb.selectstringThe value of the Select request parameter.ALL_ATTRIBUTES; COUNTRecommended
aws.dynamodb.table_namesstring[]A single-element array with the value of the TableName request parameter.[Users]Recommended

DynamoDB.Scan

AttributeTypeDescriptionExamplesRequirement Level
aws.dynamodb.segmentintThe value of the Segment request parameter.10Recommended
aws.dynamodb.total_segmentsintThe value of the TotalSegments request parameter.100Recommended
aws.dynamodb.countintThe value of the Count response parameter.10Recommended
aws.dynamodb.scanned_countintThe value of the ScannedCount response parameter.50Recommended
aws.dynamodb.attributes_to_getstring[]The value of the AttributesToGet request parameter.[lives, id]Recommended
aws.dynamodb.consistent_readbooleanThe value of the ConsistentRead request parameter.Recommended
aws.dynamodb.consumed_capacitystring[]The JSON-serialized value of each item in the ConsumedCapacity response field.[{ "CapacityUnits": number, "GlobalSecondaryIndexes": { "string" : { "CapacityUnits": number, "ReadCapacityUnits": number, "WriteCapacityUnits": number } }, "LocalSecondaryIndexes": { "string" : { "CapacityUnits": number, "ReadCapacityUnits": number, "WriteCapacityUnits": number } }, "ReadCapacityUnits": number, "Table": { "CapacityUnits": number, "ReadCapacityUnits": number, "WriteCapacityUnits": number }, "TableName": "string", "WriteCapacityUnits": number }]Recommended
aws.dynamodb.index_namestringThe value of the IndexName request parameter.name_to_groupRecommended
aws.dynamodb.limitintThe value of the Limit request parameter.10Recommended
aws.dynamodb.projectionstringThe value of the ProjectionExpression request parameter.Title; Title, Price, Color; Title, Description, RelatedItems, ProductReviewsRecommended
aws.dynamodb.selectstringThe value of the Select request parameter.ALL_ATTRIBUTES; COUNTRecommended
aws.dynamodb.table_namesstring[]A single-element array with the value of the TableName request parameter.[Users]Recommended

DynamoDB.UpdateItem

AttributeTypeDescriptionExamplesRequirement Level
aws.dynamodb.consumed_capacitystring[]The JSON-serialized value of each item in the ConsumedCapacity response field.[{ "CapacityUnits": number, "GlobalSecondaryIndexes": { "string" : { "CapacityUnits": number, "ReadCapacityUnits": number, "WriteCapacityUnits": number } }, "LocalSecondaryIndexes": { "string" : { "CapacityUnits": number, "ReadCapacityUnits": number, "WriteCapacityUnits": number } }, "ReadCapacityUnits": number, "Table": { "CapacityUnits": number, "ReadCapacityUnits": number, "WriteCapacityUnits": number }, "TableName": "string", "WriteCapacityUnits": number }]Recommended
aws.dynamodb.item_collection_metricsstringThe JSON-serialized value of the ItemCollectionMetrics response field.{ "string" : [ { "ItemCollectionKey": { "string" : { "B": blob, "BOOL": boolean, "BS": [ blob ], "L": [ "AttributeValue" ], "M": { "string" : "AttributeValue" }, "N": "string", "NS": [ "string" ], "NULL": boolean, "S": "string", "SS": [ "string" ] } }, "SizeEstimateRangeGB": [ number ] } ] }Recommended
aws.dynamodb.table_namesstring[]A single-element array with the value of the TableName request parameter.[Users]Recommended

DynamoDB.UpdateTable

AttributeTypeDescriptionExamplesRequirement Level
aws.dynamodb.attribute_definitionsstring[]The JSON-serialized value of each item in the AttributeDefinitions request field.[{ "AttributeName": "string", "AttributeType": "string" }]Recommended
aws.dynamodb.global_secondary_index_updatesstring[]The JSON-serialized value of each item in the the GlobalSecondaryIndexUpdates request field.[{ "Create": { "IndexName": "string", "KeySchema": [ { "AttributeName": "string", "KeyType": "string" } ], "Projection": { "NonKeyAttributes": [ "string" ], "ProjectionType": "string" }, "ProvisionedThroughput": { "ReadCapacityUnits": number, "WriteCapacityUnits": number } }]Recommended
aws.dynamodb.consumed_capacitystring[]The JSON-serialized value of each item in the ConsumedCapacity response field.[{ "CapacityUnits": number, "GlobalSecondaryIndexes": { "string" : { "CapacityUnits": number, "ReadCapacityUnits": number, "WriteCapacityUnits": number } }, "LocalSecondaryIndexes": { "string" : { "CapacityUnits": number, "ReadCapacityUnits": number, "WriteCapacityUnits": number } }, "ReadCapacityUnits": number, "Table": { "CapacityUnits": number, "ReadCapacityUnits": number, "WriteCapacityUnits": number }, "TableName": "string", "WriteCapacityUnits": number }]Recommended
aws.dynamodb.provisioned_read_capacitydoubleThe value of the ProvisionedThroughput.ReadCapacityUnits request parameter.1.0; 2.0Recommended
aws.dynamodb.provisioned_write_capacitydoubleThe value of the ProvisionedThroughput.WriteCapacityUnits request parameter.1.0; 2.0Recommended
aws.dynamodb.table_namesstring[]A single-element array with the value of the TableName request parameter.[Users]Recommended

S3

AttributeTypeDescriptionExamplesRequirement Level
aws.s3.bucketstringThe S3 bucket name the request refers to. Corresponds to the --bucket parameter of the S3 API operations. [1]some-bucket-nameRecommended
aws.s3.keystringThe S3 object key the request refers to. Corresponds to the --key parameter of the S3 API operations. [2]someFile.ymlRecommended
aws.s3.copy_sourcestringThe source object (in the form bucket/key) for the copy operation. [3]someFile.ymlRecommended
aws.s3.upload_idstringUpload ID that identifies the multipart upload. [4]dfRtDYWFbkRONycy.Yxwh66Yjlx.cph0gtNBtJRecommended
aws.s3.deletestringThe delete request container that specifies the objects to be deleted. [5]Objects=[{Key=string,VersionId=string},{Key=string,VersionId=string}],Quiet=booleanRecommended
aws.s3.part_numberintThe part number of the part being uploaded in a multipart-upload operation. This is a positive integer between 1 and 10,000. [6]3456Recommended

[1]: The bucket attribute is applicable to all S3 operations that reference a bucket, i.e. that require the bucket name as a mandatory parameter. This applies to almost all S3 operations except list-buckets.

[2]: The key attribute is applicable to all object-related S3 operations, i.e. that require the object key as a mandatory parameter. This applies in particular to the following operations:

[3]: The copy_source attribute applies to S3 copy operations and corresponds to the --copy-source parameter of the copy-object operation within the S3 API. This applies in particular to the following operations:

[4]: The upload_id attribute applies to S3 multipart-upload operations and corresponds to the --upload-id parameter of the S3 API multipart operations. This applies in particular to the following operations:

[5]: The delete attribute is only applicable to the delete-object operation. The delete attribute corresponds to the --delete parameter of the delete-objects operation within the S3 API.

[6]: The part_number attribute is only applicable to the upload-part and upload-part-copy operations. The part_number attribute corresponds to the --part-number parameter of the upload-part operation within the S3 API.