Configure the Elastic Distribution of OpenTelemetry Java (EDOT Java) to send data to Elastic.
Set OpenTelemetry configuration options using one of the mechanisms listed in the OpenTelemetry agent documentation and OpenTelemetry SDK documentation, including:
Configuration options set using environment variables take precedence over system properties, and system properties take precedence over configuration options set using file properties.
EDOT Java can be configured using environment variables. This is a cross-platform way to configure EDOT Java and is especially useful in containerized environments.
Define environment variables before starting the JVM:
export OTEL_SERVICE_NAME=my-service
java ...
EDOT Java can be configured using system properties. These configuration options can be seen by anything that can see the executed command-line.
Define system properties at the JVM start, usually on the command-line:
java -Dotel.service.name=my-service ...
EDOT Java can be configured using a configuration file.
Before starting the JVM, create and populate the configuration file and specify where to find it:
echo otel.service.name=my-service > my.properties
java -Dotel.javaagent.configuration-file=my.properties ...
Because the Elastic Distribution of OpenTelemetry Java is an extension of the OpenTelemetry Java agent, it supports:
- OpenTelemetry configuration options
- Configuration options from OpenTelemetry extensions that are included with EDOT Java
- Configuration options that are only available in EDOT Java
EDOT Java supports all configuration options listed in the OpenTelemetry General SDK Configuration documentation and OpenTelemetry Java agent documentation.
EDOT Java uses different defaults than the OpenTelemetry Java agent for the following configuration options:
Option | EDOT Java default | OpenTelemetry Java agent default |
---|---|---|
OTEL_RESOURCE_PROVIDERS_AWS_ENABLED |
true (enabled) | false (disabled) (docs) |
OTEL_RESOURCE_PROVIDERS_GCP_ENABLED |
true (enabled) | false (disabled) (docs) |
OTEL_INSTRUMENTATION_RUNTIME-TELEMETRY_EMIT-EXPERIMENTAL-TELEMETRY |
true (enabled) | false (disabled) (docs) |
EDOT Java includes several OpenTelemetry extensions from the OpenTelemetry Java agent contrib repo. These extensions offer the following additional OTEL_
options:
Option(s) | Extension | Description |
---|---|---|
OTEL_SERVICE_NAME |
Resource providers | This can be set as usual, but if not set the value will be inferred when the EDOT Java agent is running in various application servers. |
OTEL_INFERRED_SPANS_* |
Inferred Spans | Generates additional spans using profiling instead of instrumentation. |
In addition to general OpenTelemetry configuration options, there are two kinds of configuration options that are only available in EDOT Java.
Elastic-authored options that are not yet available upstream
Additional OTEL_
options that Elastic plans to contribute upstream to the OpenTelemetry Java agent but are not yet available in the OpenTelemetry Java agent.
Currently there are no additional OTEL_
options waiting to be contributed upstream.
Elastic-specific options
ELASTIC_OTEL_
options that are specific to Elastic and will always live in EDOT Java (in other words, they will not be added upstream):
Option(s) | Extension | Description |
---|---|---|
ELASTIC_OTEL_UNIVERSAL_PROFILING_INTEGRATION_* |
Universal profiling integration | Correlates traces with profiling data from the Elastic universal profiler. |
ELASTIC_OTEL_JAVA_SPAN_STACKTRACE_MIN_DURATION |
Span stacktrace capture | Define the minimum duration for attaching stack traces to spans. Defaults to 5ms. |
Some instrumentation are only available in EDOT Java and might or might not be added upstream in future versions.
Instrumentation for the official OpenAI Java Client. It supports:
- Tracing for requests, including GenAI-specific attributes such as token usage
- Opt-In logging of OpenAI request and response content payloads
This instrumentation is currently experimental. It can by disabled by setting either the OTEL_INSTRUMENTATION_OPENAI_CLIENT_ENABLED
environment variable or the otel.instrumentation.openai-client.enabled
JVM property to false
.
In addition, this instrumentation provides the following configuration options:
Option(s) | Description |
---|---|
ELASTIC_OTEL_JAVA_INSTRUMENTATION_GENAI_EMIT_EVENTS |
If set to true , the agent will generate log events for OpenAI requests and responses. Potentially sensitive content will only be included if OTEL_INSTRUMENTATION_GENAI_CAPTURE_MESSAGE_CONTENT is true. Defaults to the value of OTEL_INSTRUMENTATION_GENAI_CAPTURE_MESSAGE_CONTENT , so that just enabling OTEL_INSTRUMENTATION_GENAI_CAPTURE_MESSAGE_CONTENT ensures that log events are generated. |
OTEL_INSTRUMENTATION_GENAI_CAPTURE_MESSAGE_CONTENT |
If set to true , enables the capturing of OpenAI request and response content in the log events outputted by the agent. Defaults to false |
When sending data to Elastic, there are two ways you can authenticate: using an APM agent key or using a secret token. Both EDOT Java and APM Server must be configured with the same secret token for the request to be accepted.
APM agent keys are used to authorize requests to an Elastic Observability endpoint. APM agent keys are revocable, you can have more than one of them, and you can add or remove them without restarting APM Server.
To create and manage APM Agent keys in Kibana:
- Go to APM Settings.
- Select the Agent Keys tab.
When using an APM Agent key, the OTEL_EXPORTER_OTLP_HEADERS
is set using a
different auth schema (ApiKey
rather than Bearer
). For example:
export OTEL_EXPORTER_OTLP_ENDPOINT=https://my-deployment.apm.us-west1.gcp.cloud.es.io
export OTEL_EXPORTER_OTLP_HEADERS="Authorization=ApiKey TkpXUkx...dVZGQQ=="
Secret tokens are used to authorize requests to the APM Server.
You can find the values of these variables in Kibana's APM tutorial. In Kibana:
-
Go to Setup guides.
-
Select Observability.
-
Select Monitor my application performance.
-
Scroll down and select the OpenTelemetry option.
-
The appropriate values for
OTEL_EXPORTER_OTLP_ENDPOINT
andOTEL_EXPORTER_OTLP_HEADERS
are shown there. For example:export OTEL_EXPORTER_OTLP_ENDPOINT=https://my-deployment.apm.us-west1.gcp.cloud.es.io export OTEL_EXPORTER_OTLP_HEADERS="Authorization=Bearer P....l"