Configuration

The OpenTelemetrySdk.autoConfigured(...) and SdkTraces.autoConfigured(...) rely on the environment variables and system properties to configure the SDK.

There are several ways to configure the options:

Add settings to the build.sbt:

javaOptions += "-Dotel.service.name=auth-service"
envVars ++= Map("OTEL_SERVICE_NAME" -> "auth-service")

Add directives to the *.scala file:

//> using javaOpt -Dotel.service.name=auth-service
$ export OTEL_SERVICE_NAME=auth-service

Common

System property Environment variable Description
otel.sdk.disabled OTEL_SDK_DISABLED If true returns a no-op SDK instance. Default is false.

Telemetry resource

It's highly recommended to specify the service.name for your application. For example, auth-service could be an application that handles authentication requests, and jobs-dispatcher could be an application that processes background jobs.

If not specified, SDK defaults the service name to unknown_service:scala.

System property Environment variable Description
otel.resource.attributes OTEL_RESOURCE_ATTRIBUTES Specify resource attributes in the following format: key1=val1,key2=val2,key3=val3.
otel.service.name OTEL_SERVICE_NAME Specify logical service name. Takes precedence over service.name defined with otel.resource.attributes.
otel.experimental.resource.disabled-keys OTEL_EXPERIMENTAL_RESOURCE_DISABLED_KEYS Specify resource attribute keys that are filtered.
otel.otel4s.resource.detectors.enabled OTEL_OTEL4S_RESOURCE_DETECTORS_ENABLED Specify resource detectors to use. Defaults to host,os,process,process_runtime.
otel.otel4s.resource.detectors.disabled OTEL_OTEL4S_RESOURCE_DETECTORS_DISABLED Specify resource detectors to disable.

Telemetry resource detectors

TelemetryResourceDetector adds environment-aware attributes to the telemetry resource. For example, HostDetector will add host.arch and host.name attributes. By default, the following resource detectors are enabled: host, os, process, process_runtime.

To disable all detectors, set -Dotel.otel4s.resource.detectors.enabled=none. To disable some detectors, use -Dotel.otel4s.resource.detectors.disabled=host,os,process.

Metrics

Exporters

System property Environment variable Description
otel.metrics.exporter OTEL_METRICS_EXPORTER List of exporters to be export metrics, separated by commas. none means no autoconfigured exporter. Default is otlp.

Options supported out of the box:

OTLP exporter

The exporter can be configured by two sets of settings:

Global properties can be used to configure span and metric exporters simultaneously. Global otel.exporter.otlp.endpoint must be a base URL. The configurer automatically adds path (i.e. v1/metrics) to the URL.

Target-specific properties are prioritized. E.g. otel.exporter.otlp.metrics.endpoint is prioritized over otel.exporter.otlp.endpoint.

System property Environment variable Description
otel.exporter.otlp.protocol OTEL_EXPORTER_OTLP_PROTOCOL The transport protocol to use. Options include grpc, http/protobuf, and http/json. Default is http/protobuf.
otel.exporter.otlp.endpoint OTEL_EXPORTER_OTLP_ENDPOINT The OTLP traces, metrics, and logs endpoint to connect to. Must be a base URL with a scheme of either http or https based on the use of TLS. Default is http://localhost:4318/.
otel.exporter.otlp.headers OTEL_EXPORTER_OTLP_HEADERS Key-value pairs separated by commas to pass as request headers on OTLP trace, metric, and log requests.
otel.exporter.otlp.compression OTEL_EXPORTER_OTLP_COMPRESSION The compression type to use on OTLP trace, metric, and log requests. Options include gzip. By default, no compression will be used.
otel.exporter.otlp.timeout OTEL_EXPORTER_OTLP_TIMEOUT The maximum waiting time to send each OTLP trace, metric, and log batch. Default is 10 seconds.
Target specific:
otel.exporter.otlp.metrics.protocol OTEL_EXPORTER_OTLP_METRICS_PROTOCOL The transport protocol to use. Options include grpc, http/protobuf, and http/json. Default is http/protobuf.
otel.exporter.otlp.metrics.endpoint OTEL_EXPORTER_OTLP_METRICS_ENDPOINT The OTLP metrics endpoint to connect to. Default is http://localhost:4318/v1/metrics.
otel.exporter.otlp.metrics.headers OTEL_EXPORTER_OTLP_METRICS_HEADERS Key-value pairs separated by commas to pass as request headers on OTLP trace requests.
otel.exporter.otlp.metrics.compression OTEL_EXPORTER_OTLP_METRICS_COMPRESSION The compression type to use on OTLP trace requests. Options include gzip. By default, no compression will be used.
otel.exporter.otlp.metrics.timeout OTEL_EXPORTER_OTLP_METRICS_TIMEOUT The maximum waiting time to send each OTLP trace batch. Default is 10 seconds.

Prometheus exporter

The exporter launches an HTTP server which responds to the HTTP requests with Prometheus metrics in the appropriate format.

System property Environment variable Description
otel.exporter.prometheus.host OTEL_EXPORTER_PROMETHEUS_HOST The host that metrics are served on. Default is localhost.
otel.exporter.prometheus.port OTEL_EXPORTER_PROMETHEUS_PORT The port that metrics are served on. Default is 9464.
otel.exporter.prometheus.default.aggregation OTEL_EXPORTER_PROMETHEUS_DEFAULT_AGGREGATION Default aggregation as a function of instrument kind. Default is default.
otel.exporter.prometheus.without.units OTEL_EXPORTER_PROMETHEUS_WITHOUT_UNITS If metrics are produced without a unit suffix. Default is false.
otel.exporter.prometheus.without.type.suffix OTEL_EXPORTER_PROMETHEUS_WITHOUT_TYPE_SUFFIX If metrics are produced without a type suffix. Default is false.
otel.exporter.prometheus.without.scope.info OTEL_EXPORTER_PROMETHEUS_WITHOUT_SCOPE_INFO If metrics are produced without a scope info metric or scope labels. Default is false.
otel.exporter.prometheus.without.target.info OTEL_EXPORTER_PROMETHEUS_WITHOUT_TARGET_INFO If metrics are produced without a target info metric. Default is false.
otel.exporter.prometheus.shutdown.timeout OTEL_EXPORTER_PROMETHEUS_SHUTDOWN_TIMEOUT The time to wait for provider to do any cleanup required. Default is 10 seconds.

Period metric reader

Period metric reader pushes metrics to the push-based exporters (e.g. OTLP) over a fixed interval.

System property Environment variable Description
otel.metric.export.interval OTEL_METRIC_EXPORT_INTERVAL The time interval between the start of two export attempts. Default is 1 minute.
otel.metric.export.timeout OTEL_METRIC_EXPORT_TIMEOUT Maximum allowed time to export data. Default is 30 seconds.

Exemplar filter

The exemplar filter decides whether the measurement will be recorded as an exemplar.

System property Environment variable Description
otel.metrics.exemplar.filter OTEL_METRICS_EXEMPLAR_FILTER The exemplar filter to use. Default is trace_based.

The following options for otel.metrics.exemplar.filter are supported:

Tracing

Exporters

System property Environment variable Description
otel.traces.exporter OTEL_TRACES_EXPORTER List of exporters to be export spans, separated by commas. none means no autoconfigured exporter. Default is otlp.

Options supported out of the box:

OTLP exporter

The exporter can be configured by two sets of settings:

Global properties can be used to configure span and metric exporters simultaneously. Global otel.exporter.otlp.endpoint must be a base URL. The configurer automatically adds path (i.e. v1/traces) to the URL.

Target-specific properties are prioritized. E.g. otel.exporter.otlp.traces.endpoint is prioritized over otel.exporter.otlp.endpoint.

System property Environment variable Description
otel.exporter.otlp.protocol OTEL_EXPORTER_OTLP_PROTOCOL The transport protocol to use. Options include grpc, http/protobuf, and http/json. Default is http/protobuf.
otel.exporter.otlp.endpoint OTEL_EXPORTER_OTLP_ENDPOINT The OTLP traces, metrics, and logs endpoint to connect to. Must be a base URL with a scheme of either http or https based on the use of TLS. Default is http://localhost:4318/.
otel.exporter.otlp.headers OTEL_EXPORTER_OTLP_HEADERS Key-value pairs separated by commas to pass as request headers on OTLP trace, metric, and log requests.
otel.exporter.otlp.compression OTEL_EXPORTER_OTLP_COMPRESSION The compression type to use on OTLP trace, metric, and log requests. Options include gzip. By default, no compression will be used.
otel.exporter.otlp.timeout OTEL_EXPORTER_OTLP_TIMEOUT The maximum waiting time to send each OTLP trace, metric, and log batch. Default is 10 seconds.
Target specific:
otel.exporter.otlp.metrics.protocol OTEL_EXPORTER_OTLP_TRACES_PROTOCOL The transport protocol to use. Options include grpc, http/protobuf, and http/json. Default is http/protobuf.
otel.exporter.otlp.traces.endpoint OTEL_EXPORTER_OTLP_TRACES_ENDPOINT The OTLP traces endpoint to connect to. Default is http://localhost:4318/v1/traces.
otel.exporter.otlp.traces.headers OTEL_EXPORTER_OTLP_TRACES_HEADERS Key-value pairs separated by commas to pass as request headers on OTLP trace requests.
otel.exporter.otlp.traces.compression OTEL_EXPORTER_OTLP_TRACES_COMPRESSION The compression type to use on OTLP trace requests. Options include gzip. By default, no compression will be used.
otel.exporter.otlp.traces.timeout OTEL_EXPORTER_OTLP_TRACES_TIMEOUT The maximum waiting time to send each OTLP trace batch. Default is 10 seconds.

Propagators

The propagators determine which distributed tracing header formats are used, and which baggage propagation header formats are used.

System property Environment variable Description
otel.propagators OTEL_PROPAGATORS The propagators to use. Use a comma-separated list for multiple propagators. Default is tracecontext,baggage (W3C).

Options supported out of the box:

Batch span processor

System property Environment variable Description
otel.bsp.schedule.delay OTEL_BSP_SCHEDULE_DELAY The interval between two consecutive exports. Default is 5 seconds.
otel.bsp.max.queue.size OTEL_BSP_MAX_QUEUE_SIZE The maximum queue size. Default is 2048.
otel.bsp.max.export.batch.size OTEL_BSP_MAX_EXPORT_BATCH_SIZE The maximum batch size. Default is 512.
otel.bsp.export.timeout OTEL_BSP_EXPORT_TIMEOUT The maximum allowed time to export data. Default is 30 seconds.

Sampler

The sampler decides whether spans will be recorded.

System property Environment variable Description
otel.traces.sampler OTEL_TRACES_SAMPLER The sampler to use for tracing. Defaults to parentbased_always_on.
otel.traces.sampler.arg OTEL_TRACES_SAMPLER_ARG An argument to the configured tracer if supported, for example, a ratio.

The following options for otel.traces.sampler are supported out of the box:

Span limits

These properties can be used to control the maximum size of spans by placing limits on attributes, events, and links.

System property Environment variable Description
otel.span.attribute.count.limit OTEL_SPAN_ATTRIBUTE_COUNT_LIMIT The maximum allowed span attribute count. Default is 128.
otel.span.event.count.limit OTEL_SPAN_EVENT_COUNT_LIMIT The maximum allowed span event count. Default is 128.
otel.span.link.count.limit OTEL_SPAN_LINK_COUNT_LIMIT The maximum allowed span link count. Default is 128.
otel.event.attribute.count.limit OTEL_EVENT_ATTRIBUTE_COUNT_LIMIT The maximum allowed attribute per span event count. Default is 128.
otel.link.attribute.count.limit OTEL_LINK_ATTRIBUTE_COUNT_LIMIT The maximum allowed attribute per span link count. Default is 128.
otel.span.attribute.value.length.limit OTEL_SPAN_ATTRIBUTE_VALUE_LENGTH_LIMIT The maximum allowed attribute value size. No limit by default.