このガイドは統合します:
OpenTelemetry Lambdaレイヤーのインストール
OpenTelemetryプロジェクトは、以下の目的で別々のLambdaレイヤーを提供します:
- OpenTelemetryの自動計測を使用して、Lambda関数のコードを自動的に計測します。
- 収集したログ、メトリクス、トレースをClickStackに転送します。
言語固有の自動計測レイヤーの追加
言語固有の自動計測Lambdaレイヤーは、特定の言語用のOpenTelemetry自動計測パッケージを使用して、Lambda関数のコードを自動的に計測します。
各言語とリージョンごとに独自のレイヤーARNがあります。
LambdaがすでにOpenTelemetry SDKで計測されている場合は、このステップをスキップできます。
始めるには:
- Layersセクションで「Add a layer」をクリックします。
- ARNを指定し、言語に基づいて正しいARNを選択し、
<region>を自分のリージョン(例:us-east-2)に置き換えてください:
arn:aws:lambda:<region>:184161586896:layer:opentelemetry-nodejs-0_7_0:1
arn:aws:lambda:<region>:184161586896:layer:opentelemetry-python-0_7_0:1
arn:aws:lambda:<region>:184161586896:layer:opentelemetry-javaagent-0_6_0:1
arn:aws:lambda:<region>:184161586896:layer:opentelemetry-ruby-0_1_0:1
レイヤーの最新リリースは、OpenTelemetry Lambda Layers GitHubリポジトリで見つけることができます。
- Lambda関数の「Configuration」>「Environment variables」で次の環境変数を設定します。
OTEL_EXPORTER_OTLP_ENDPOINT=http://localhost:4318
AWS_LAMBDA_EXEC_WRAPPER=/opt/otel-handler
OTEL_PROPAGATORS=tracecontext
OTEL_TRACES_SAMPLER=always_on
OTEL_EXPORTER_OTLP_ENDPOINT=http://localhost:4318
AWS_LAMBDA_EXEC_WRAPPER=/opt/otel-instrument
OTEL_PROPAGATORS=tracecontext
OTEL_TRACES_SAMPLER=always_on
OTEL_EXPORTER_OTLP_ENDPOINT=http://localhost:4318
AWS_LAMBDA_EXEC_WRAPPER=/opt/otel-handler
OTEL_PROPAGATORS=tracecontext
OTEL_TRACES_SAMPLER=always_on
OTEL_EXPORTER_OTLP_ENDPOINT=http://localhost:4318
AWS_LAMBDA_EXEC_WRAPPER=/opt/otel-handler
OTEL_PROPAGATORS=tracecontext
OTEL_TRACES_SAMPLER=always_on
OpenTelemetryコレクタLambdaレイヤーのインストール
コレクタLambdaレイヤーを使用すると、Lambda関数からClickStackにログ、メトリクス、トレースを転送でき、エクスポータの遅延による応答時間への影響を最小限に抑えることができます。
コレクタレイヤーをインストールするには:
- Layersセクションで「Add a layer」をクリックします。
- ARNを指定し、アーキテクチャに基づいて正しいARNを選択し、
<region>を自分のリージョン(例:us-east-2)に置き換えてください:
arn:aws:lambda:<region>:184161586896:layer:opentelemetry-collector-amd64-0_8_0:1
arn:aws:lambda:<region>:184161586896:layer:opentelemetry-collector-arm64-0_8_0:1
- コレクタをClickStackに送信するように設定するために、プロジェクトに次の
collector.yamlファイルを追加します:
# collector.yaml
receivers:
otlp:
protocols:
grpc:
endpoint: 'localhost:4317'
http:
endpoint: 'localhost:4318'
processors:
batch:
decouple:
exporters:
otlphttp:
endpoint: "<YOU_OTEL_COLLECTOR_HTTP_ENDPOINT>
headers:
authorization: <YOUR_INGESTION_API_KEY>
compression: gzip
service:
pipelines:
traces:
receivers: [otlp]
processors: [batch, decouple]
exporters: [otlphttp]
metrics:
receivers: [otlp]
processors: [batch, decouple]
exporters: [otlphttp]
logs:
receivers: [otlp]
processors: [batch, decouple]
exporters: [otlphttp]
- 次の環境変数を追加します:
OPENTELEMETRY_COLLECTOR_CONFIG_FILE=/var/task/collector.yaml
インストールの確認
レイヤーをデプロイした後、Lambda関数から自動的に収集されたトレースがHyperDXに表示されるはずです。decoupleおよびbatchingプロセッサはテレメトリコレクションに遅延を引き起こす可能性があるため、トレースが表示されるまでに時間がかかる場合があります。カスタムログやメトリクスを生成するには、言語固有のOpenTelemetry SDKを使用してコードを計測する必要があります。
トラブルシューティング
カスタム計測が送信されない
手動で定義したトレースやその他のテレメトリが表示されない場合、OpenTelemetry APIパッケージの互換性のないバージョンを使用している可能性があります。OpenTelemetry APIパッケージがAWS Lambdaに含まれるバージョンと同じか、それよりも古いバージョンであることを確認してください。
SDKデバッグログの有効化
OTEL_LOG_LEVEL環境変数をDEBUGに設定して、OpenTelemetry SDKからのデバッグログを有効にします。これにより、自動計測レイヤーがアプリケーションを正しく計測していることを確認できます。
コレクタデバッグログの有効化
コレクタの問題をデバッグするには、コレクタの設定ファイルを変更してloggingエクスポータを追加し、テレメトリログレベルをdebugに設定して、コレクタLambdaレイヤーからの詳細なログを有効にします。
# collector.yaml
receivers:
otlp:
protocols:
grpc:
endpoint: 'localhost:4317'
http:
endpoint: 'localhost:4318'
exporters:
logging:
verbosity: detailed
otlphttp:
endpoint: "https://in-otel.hyperdx.io"
headers:
authorization: <YOUR_INGESTION_API_KEY>
compression: gzip
service:
telemetry:
logs:
level: "debug"
pipelines:
traces:
receivers: [otlp]
processors: [batch, decouple]
exporters: [otlphttp, logging]
metrics:
receivers: [otlp]
processors: [batch, decouple]
exporters: [otlphttp, logging]
logs:
receivers: [otlp]
processors: [batch, decouple]
exporters: [otlphttp, logging]