Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

github.com/open-telemetry/opentelemetry-collector-contrib/exporter/awsxrayexporter

Package Overview
Dependencies
Alerts
File Explorer
Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

github.com/open-telemetry/opentelemetry-collector-contrib/exporter/awsxrayexporter

  • v0.117.0
  • Source
  • Go
  • Socket score

Version published
Created
Source

AWS X-Ray Tracing Exporter for OpenTelemetry Collector

Status
Stabilitybeta: traces
Distributionscontrib
IssuesOpen issues Closed issues
Code Owners@wangzlei, @srprash

This exporter converts OpenTelemetry spans to AWS X-Ray Segment Documents and then sends them directly to X-Ray using the PutTraceSegments API.

Data Conversion

Trace IDs and Span IDs are expected to be originally generated by either AWS API Gateway or AWS ALB and propagated by them using the X-Amzn-Trace-Id HTTP header. However, other generation sources are supported by replacing fully-random Trace IDs with X-Ray formatted Trace IDs where necessary:

AWS X-Ray IDs in binary are 128 bits, the same size as W3C Trace Context IDs but the string is formatted to “1-{8 digit hex}-{24 digit hex}“. For example, The W3C format trace ID “4bf92f3577b34da6a3ce929d0e0e4736” is converted to the X-Ray format trace ID “1-4bf92f35-77b34da6a3ce929d0e0e4736".

The http object is populated when the component attribute value is grpc as well as http. Other synchronous call types should also result in the http object being populated.

AWS Specific Attributes

The following AWS-specific Span attributes are supported in addition to the standard names and values defined in the OpenTelemetry Semantic Conventions.

Attribute nameNotes and examplesRequired?
aws.operationThe name of the API action invoked against an AWS service or resource.No
aws.account_idThe AWS account number if accessing resource in different account.No
aws.regionThe AWS region if accessing resource in different region from app.No
aws.request_idAWS-generated unique identifier for the request.No
aws.queue_urlFor operations on an Amazon SQS queue, the queue's URL.No
aws.table_nameFor operations on a DynamoDB table, the name of the table.No
aws.xray.annotationsThe attribute is a slice(list) attribute that contains each of the string keys. If found on the span, the awsxrayexporter will use them in addition to the indexed_attributes configuration field when categorizing which attributes to index. This can be configured with "aws.xray.annotations"=["key1", "key2"] (Java example: span.setAttribute(stringArrayKey("aws.xray.annotations"), List.of("key1", "key2")))No

Any of these values supplied are used to populate the aws object in addition to any relevant data supplied by the Span Resource object. X-Ray uses this data to generate inferred segments for the remote APIs.

Exporter Configuration

The following exporter configuration parameters are supported. They mirror and have the same effect as the comparable AWS X-Ray Daemon configuration values.

NameDescriptionDefault
num_workersMaximum number of concurrent calls to AWS X-Ray to upload documents.8
endpointOptionally override the default X-Ray service endpoint.
request_timeout_secondsNumber of seconds before timing out a request.30
max_retriesMaximun number of attempts to post a batch before failing.2
no_verify_sslEnable or disable TLS certificate verification.false
proxy_addressUpload segments to AWS X-Ray through a proxy.
regionSend segments to AWS X-Ray service in a specific region.
local_modeLocal mode to skip EC2 instance metadata check.false
resource_arnAmazon Resource Name (ARN) of the AWS resource running the collector.
role_arnIAM role to upload segments to a different account.
indexed_attributesList of attribute names to be converted to X-Ray annotations.
index_all_attributesEnable or disable conversion of all OpenTelemetry attributes to X-Ray annotations.false
aws_log_groupsList of log group names for CloudWatch.[]
telemetry.enabledWhether telemetry collection is enabled at all.false
telemetry.include_metadataWhether to include metadata in the telemetry (InstanceID, Hostname, ResourceARN)false
telemetry.contributorsList of X-Ray component IDs contributing to the telemetry (ex. for multiple X-Ray receivers: awsxray/1, awsxray/2)
telemetry.hostnameSets the Hostname included in the telemetry.
telemetry.instance_idSets the InstanceID included in the telemetry.
telemetry.resource_arnSets the Amazon Resource Name (ARN) included in the telemetry.

Traces and logs correlation

AWS X-Ray can be integrated with CloudWatch Logs to correlate traces with logs. For this integration to work, the X-Ray segments must have the AWS Property cloudwatch_logs set. This property is set using the AWS X-Ray exporter with the following values that are evaluated in this order:

  1. aws.log.group.arns resource attribute.
  2. aws.log.group.names resource attribute.
  3. aws_log_groups configuration property.

In the case of multiple values are defined, the value with higher precedence will be used to set the cloudwatch_logs AWS Property.

aws.log.group.arns and aws.log.group.names are slice resource attributes that can be set programmatically. Alternatively those resource attributes can be set using the OTEL_RESOURCE_ATTRIBUTES environment variable. To set multiple log group names /log group arns, you can use & to separate them. For example, 3 log groups log-group1, log-group2, and log-group3 are set in the following command:

export OTEL_RESOURCE_ATTRIBUTES="aws.log.group.names=log-group1&log-group2&log-group3"

AWS Credential Configuration

This exporter follows default credential resolution for the aws-sdk-go.

Follow the guidelines for the credential configuration.

FAQs

Package last updated on 08 Jan 2025

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc