Skip to content

Create your own Lambda Layer in each OTel language using this starter code. Add the Lambda Layer to your Lamdba Function to get tracing with OpenTelemetry.

License

Notifications You must be signed in to change notification settings

logzio/opentelemetry-lambda

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

OpenTelemetry Lambda

GitHub Java Workflow Status GitHub Collector Workflow Status GitHub NodeJS Workflow Status GitHub Terraform Lint Workflow Status GitHub Python Pull Request Workflow Status

OpenTelemetry Lambda Layers

The OpenTelemetry Lambda Layers provide the OpenTelemetry (OTel) code to export telemetry asynchronously from AWS Lambda functions. It does this by embedding a stripped-down version of OpenTelemetry Collector Contrib inside an AWS Lambda Extension Layer.

Some layers include the corresponding OTel language SDK for the Lambda. This allows Lambda functions to use OpenTelemetry to send traces and metrics to any configured backend.

Extension Layer Language Support

FAQ

  • What exporters/receivers/processors are included from the OpenTelemetry Collector?

    You can check out the stripped-down collector's imports in this repository for a full list of currently included components.

    Self-built binaries of the collector have experimental support for a custom set of connectors/exporters/receivers/processors. For more information, see (Experimental) Customized collector build

  • Is the Lambda layer provided or do I need to build it and distribute it myself?

    This repository provides pre-built Lambda layers, their ARNs are available in the Releases. You can also build the layers manually and publish them in your AWS account. This repo has files to facilitate doing that. More information is provided in the Collector folder's README.

Design Proposal

To get a better understanding of the proposed design for the OpenTelemetry Lambda extension, you can see the Design Proposal here.

Features

The following is a list of features provided by the OpenTelemetry layers.

OpenTelemetry collector

The layer includes the OpenTelemetry Collector as a Lambda extension.

Custom context propagation carrier extraction

Context can be propagated through various mechanisms (e.g. http headers (APIGW), message attributes (SQS), ...). In some cases, it may be required to pass a custom context propagation extractor in Lambda through configuration, this feature allows this through Lambda instrumentation configuration.

X-Ray Env Var Span Link

This links a context extracted from the Lambda runtime environment to the instrumentation-generated span rather than disabling that context extraction entirely.

Semantic conventions

The Lambda language implementation follows the semantic conventions specified in the OpenTelemetry Specification.

Auto instrumentation

The Lambda layer includes support for automatically instrumentation code via the use of instrumentation libraries.

Flush TracerProvider

The Lambda instrumentation will flush the TracerProvider at the end of an invocation.

Flush MeterProvider

The Lambda instrumentation will flush the MeterProvider at the end of an invocation.

Support matrix

The table below captures the state of various features and their levels of support different runtimes.

Feature Node Python Java .NET Go Ruby
OpenTelemetry collector + + + + + +
Custom context propagation + - - - N/A +
X-Ray Env Var Span Link - - - - N/A -
Semantic Conventions^ + + + N/A +
- Trace General^1 + + + N/A +
- Trace Incoming^2 - - + N/A -
- Trace Outgoing^3 + - + N/A +
- Metrics^4 - - - N/A -
Auto instrumentation + + + - N/A +
Flush TracerProvider + + + + +
Flush MeterProvider + + -

Legend

  • + is supported
  • - not supported
  • ^ subject to change depending on spec updates
  • N/A not applicable to the particular language
  • blank cell means the status of the feature is not known.

The following are runtimes which are no longer or not yet supported by this repository:

Contributing

See the Contributing Guide for details.

Here is a list of community roles with current and previous members:

Learn more about roles in the community repository.

Configuration Example

Replace <<LOGZIO_TRACING_SHIPPING_TOKEN>>, <<LOGZIO_SPM_SHIPPING_TOKEN>>, <<LOGZIO_ACCOUNT_REGION_CODE>>, and <<LOGZIO_LISTENER_HOST>> with your Logz.io account's information.

receivers:
  otlp:
    protocols:
      grpc:
        endpoint: "0.0.0.0:4317"
      http:
        endpoint: "0.0.0.0:4318"

connectors:
  spanmetrics:
    aggregation_temporality: AGGREGATION_TEMPORALITY_CUMULATIVE
    dimensions:
      - name: rpc.grpc.status_code
      - name: http.method
      - name: http.status_code
      - name: cloud.provider
      - name: cloud.region
      - name: db.system
      - name: messaging.system
      - default: DEV
        name: env_id
    dimensions_cache_size: 100000
    histogram:
      explicit:
        buckets:
          - 2ms
          - 8ms
          - 50ms
          - 100ms
          - 200ms
          - 500ms
          - 1s
          - 5s
          - 10s
    metrics_expiration: 5m
    resource_metrics_key_attributes:
      - service.name
      - telemetry.sdk.language
      - telemetry.sdk.name

exporters:
  logzio/traces:
    account_token: <<LOGZIO_TRACING_SHIPPING_TOKEN>>
    region: <<LOGZIO_ACCOUNT_REGION_CODE>>
  prometheusremotewrite/spm:
    endpoint: https://<<LOGZIO_LISTENER_HOST>>:8053
    add_metric_suffixes: false
    headers:
      Authorization: Bearer <<LOGZIO_SPM_SHIPPING_TOKEN>>

processors:
  batch:
  tail_sampling:
    policies:
      - name: policy-errors
        type: status_code
        status_code: {status_codes: [ERROR]}
      - name: policy-slow
        type: latency
        latency: {threshold_ms: 1000}
      - name: policy-random-ok
        type: probabilistic
        probabilistic: {sampling_percentage: 10}
  metricstransform/metrics-rename:
    transforms:
    - include: ^duration(.*)$$
      action: update
      match_type: regexp
      new_name: latency.$${1} 
    - action: update
      include: calls
      new_name: calls_total
  metricstransform/labels-rename:
    transforms:
    - action: update
      include: ^latency
      match_type: regexp
      operations:
      - action: update_label
        label: span.name
        new_label: operation
    - action: update
      include: ^calls
      match_type: regexp
      operations:
      - action: update_label
        label: span.name
        new_label: operation  

service:
  pipelines:
    traces:
      receivers: [otlp]
      processors: [tail_sampling, batch]
      exporters: [logzio/traces]
    traces/spm:
      receivers: [otlp]
      processors: [batch]
      exporters: [spanmetrics]
    metrics/spanmetrics:
      receivers: [spanmetrics]
      processors: [metricstransform/metrics-rename, metricstransform/labels-rename, batch]
      exporters: [prometheusremotewrite/spm]
  telemetry: 
    logs:
      level: "info"

About

Create your own Lambda Layer in each OTel language using this starter code. Add the Lambda Layer to your Lamdba Function to get tracing with OpenTelemetry.

Topics

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Go 64.4%
  • HCL 9.2%
  • Shell 5.6%
  • Python 5.4%
  • TypeScript 4.7%
  • Java 3.8%
  • Other 6.9%