Declarative configuration
You are viewing the English version of this page because it has not yet been fully translated. Interested in helping out? See Contributing.
Declarative configuration uses a YAML file instead of environment variables.
This approach is useful when:
- You have many configuration options to set.
- You want to use configuration options that are not available as environment variables.
Declarative configuration is experimental.
Supported languages
The following OpenTelemetry SDKs support declarative configuration:
For details, refer to the Compliance Matrix
Getting started
- Save the following configuration file as otel-config.yaml.
- Set the environment variable
OTEL_EXPERIMENTAL_CONFIG_FILE=/path/to/otel-config.yaml
Recommended configuration file:
file_format: '1.0-rc.1'
resource:
  attributes_list: ${OTEL_RESOURCE_ATTRIBUTES}
  detection/development:
    detectors:
      - service: # will add "service.instance.id" and "service.name" from OTEL_SERVICE_NAME
tracer_provider:
  processors:
    - batch:
        exporter:
          otlp_http:
            endpoint: ${OTEL_EXPORTER_OTLP_ENDPOINT:-http://localhost:4318}/v1/traces
meter_provider:
  readers:
    - periodic:
        exporter:
          otlp_http:
            endpoint: ${OTEL_EXPORTER_OTLP_ENDPOINT:-http://localhost:4318}/v1/metrics
logger_provider:
  processors:
    - batch:
        exporter:
          otlp_http:
            endpoint: ${OTEL_EXPORTER_OTLP_ENDPOINT:-http://localhost:4318}/v1/logs
Environment variables
- Declarative configuration supports syntax to read environment variables.
- All environment variables are ignored unless you explicitly add them to the config file.
For example, if you set:
OTEL_RESOURCE_ATTRIBUTES=service.version=1.1,deployment.environment.name=staging
The following config will create a resource with service.version=1.1 and
deployment.environment.name=staging:
resource:
  attributes_list: ${OTEL_RESOURCE_ATTRIBUTES}
All environment variables are ignored unless you explicitly add them to the config file.
Migration configuration
If your existing configuration relies on environment variables, you can use the migration configuration as a starting point to migrate to declarative configuration.
Available config options
A complete list of config options can be found in the kitchen sink example.
Endpoint per signal
If you have different endpoints for traces, metrics, and logs, use the following
config when using otlp_http:
| OTLP HTTP Exporter | Endpoint value | 
|---|---|
| Traces | ${OTEL_EXPORTER_OTLP_TRACES_ENDPOINT:-http://localhost:4318/v1/traces} | 
| Metrics | ${OTEL_EXPORTER_OTLP_METRICS_ENDPOINT:-http://localhost:4318/v1/metrics} | 
| Logs | ${OTEL_EXPORTER_OTLP_LOGS_ENDPOINT:-http://localhost:4318/v1/logs} | 
gRPC Exporter
Instead of otlp_http, you can also use otlp_grpc to export via gRPC:
otlp_grpc:
  endpoint: ${OTEL_EXPORTER_OTLP_ENDPOINT:-http://localhost:4317}
Resource Attributes
The recommended approach to set resource attributes is via environment variables, because it works well with tools that set environment variables, such as OpenTelemetry Operator for Kubernetes.
However, you can also set resource attributes directly in the config file:
resource:
  attributes:
    - name: service.name
      value: shopping_cart
    - name: deployment.environment.name
      value: staging
Feedback
Was this page helpful?
Thank you. Your feedback is appreciated!
Please let us know how we can improve this page. Your feedback is appreciated!