Instrumenting your application in Docker Compose
This is just a neat trick that allows you to collect observability data from your application running via Docker Compose without changing the original docker-compose.yml file. We accomplish this by using an override file that will add the OTEL agent and set the appropriate environment variables which we can use in dev/test.
Prerequisite: Create an environment in Digma
Follow these instructions to create a private or CI/prod environment depending on your use case and required visibility for the new environment.
1. Download the latest OTEL and Digma agents
2. Add a Docker Compose override file
Create a supplementary Docker Compose file that will include the agent files and provide the environment variables to export tracing data to Digma.
#docker-compose.override.otel.yml
version: '3'
services:
[your-service]:
volumes:
- "./otel/opentelemetry-javaagent.jar:/otel/opentelemetry-javaagent.jar"
- "./otel/digma-agent.jar:/otel/digma-agent.jar"
- "./otel/digma-otel-agent-extension.jar:/otel/digma-otel-agent-extension.jar"
environment:
- JAVA_TOOL_OPTIONS=-javaagent:/otel/digma-agent.jar -javaagent:/otel/opentelemetry-javaagent.jar -Dotel.javaagent.extensions=/otel/digma-otel-agent-extension.jar
- OTEL_SERVICE_NAME=[your-service]
- OTEL_EXPORTER_OTLP_ENDPOINT=http://host.docker.internal:5050
- OTEL_METRICS_EXPORTER=none
- OTEL_LOGS_EXPORTER=none
- OTEL_EXPORTER_OTLP_PROTOCOL=grpc
- OTEL_RESOURCE_ATTRIBUTES=digma.environment=[ENV_NAME],digma.environment.type=Public
- OTEL_INSTRUMENTATION_COMMON_EXPERIMENTAL_CONTROLLER_TELEMETRY_ENABLED=true
- OTEL_INSTRUMENTATION.EXPERIMENTAL_VIEW_TELEMETRY_ENABLED=true
- OTEL_INSTRUMENTATION.EXPERIMENTAL_SPAN_SUPPRESSION_STRATEGY=none
- OTEL_INSTRUMENTATION_JDBC_DATASOURCE_ENABLED=true
extra_hosts:
- "host.docker.internal:host-gateway"
If you've created a private environment, use the following value for OTEL_RESOURCE_ATTRIBUTES
instead of what is listed above:
OTEL_RESOURCE_ATTRIBUTES=digna.environment=[ENV_NAME],digma.environment.type=Private,digma.user.id=[USER_ID]
To retrieve the values for ENV_NAME, USER_ID, or ENV_TYPE click on the How to setup
option in the observability panel on the environment tab.
3. Run your original Docker Compose file along with the override file
docker compose -f docker-compose.yml -f docker-compose.override.otel.yml up -d
Last updated