Files
Christopher Petito 970fc1b6f7 Basic compose file for testing OTEL bits
Signed-off-by: Christopher Petito <chrisjpetito@gmail.com>
2025-04-09 13:48:04 +02:00
..

Sample stack for testing OTEL functionality with moby

To easily test the OTEL functionality present in moby, you can spin up a small demo compose stack that includes:

  • an OTEL collector container;
  • a Jaeger container to visualize traces;
  • an alternative Aspire Dashboard container to visualize traces;

The OTEL collector is configured to export Traces to both the Jaeger and Aspire containers.

The contrib/otel directory contains the compose file with the services configured, along with a basic configuration file for the OTEL collector.

How can I use it?

  1. Export the env var used to override the OTLP endpoint:
    export OTEL_EXPORTER_OTLP_ENDPOINT=http://localhost:4318 (if running in a devcontainer or in other ways, you might have to change how you pass this env var to the daemon);
  2. Start the moby engine you want to get traces from (make sure it gets the env var declared above);
  3. Start the otel compose stack by running docker compose up -d in the contrib/otel/ directory;
  4. Make some calls to the engine using the Docker CLI to send some traces to the endpoint;
  5. Browse Jaeger at http://localhost:16686 or the Aspire Dashboard at http://localhost:18888/traces;
  6. To see some traces from the engine, select dockerd in the top left dropdown

Note

: The precise steps may vary based on how you're working on the codebase (buiding a binary and executing natively, running/debugging in a devcontainer, etc... )

Cleanup?

Simply run docker compose down in the contrib/otel/ directory.

You can also run unset OTEL_EXPORTER_OTLP_ENDPOINT to get rid of the OTLP env var from your environment