Ukraine flag We stand with our friends and colleagues in Ukraine. To support Ukraine in their time of need visit this page.

Deployment

Version  next-release-v2 Preview Latest Go to the latest 1.x version

See also:


The main Jaeger backend components are released as Docker images on Docker Hubexternal link and Quayexternal link:

!!!UPDATE THE TABLE BELOW

ComponentDocker HubQuay
jaeger-all-in-onehub.docker.com/r/jaegertracing/all-in-one/external linkquay.io/repository/jaegertracing/all-in-oneexternal link
jaeger-agenthub.docker.com/r/jaegertracing/jaeger-agent/external linkquay.io/repository/jaegertracing/jaeger-agentexternal link
jaeger-collectorhub.docker.com/r/jaegertracing/jaeger-collector/external linkquay.io/repository/jaegertracing/jaeger-collectorexternal link
jaeger-queryhub.docker.com/r/jaegertracing/jaeger-query/external linkquay.io/repository/jaegertracing/jaeger-queryexternal link
jaeger-ingesterhub.docker.com/r/jaegertracing/jaeger-ingester/external linkquay.io/repository/jaegertracing/jaeger-ingesterexternal link
jaeger-remote-storagehub.docker.com/r/jaegertracing/jaeger-remote-storage/external linkquay.io/repository/jaegertracing/jaeger-remote-storageexternal link

The images listed above are the primary release versions. Most components have additional images published:

  • ${component}-debug images include Delve debugger
  • ${component}-snapshot images are published from the tip of the main branch for every commit, allowing testing of unreleased versions
  • ${component}-debug-snapshot snapshot images that include the Delve debugger

There are orchestration templates for running Jaeger with:

Configuration Options

jaeger binaries are configured via configuration YAML file. The following ports are exposed by default:

PortProtocolFunction
2777HTTPexpvar port for process level metrics per the Go standards
8888HTTPmetrics port for exposing metrics which can be scraped with Prometheus compatible systems at /metrics
8889HTTPingester port for reading data from Kafka topics and writing to a supported backend
13133HTTPHealthcheck port via the healthcheckv2 extension

jaeger is stateless and thus many instances of jaeger can be run in parallel. jaeger instances require almost no configuration, except for storage location, such as:

Cassandra:

  jaeger_storage:
    backends:
      some_storage:
        cassandra:
          schema: 
            keyspace: "jaeger_v1_dc1"
          connection:
            auth: 
              basic:
                username: "cassandra"
                password: "cassandra"
            tls:
              insecure: true

OpenSearch:

  jaeger_storage:
    backends:
      some_storage:
        opensearch:
          index_prefix: "jaeger-main"

ElasticSearch:

  jaeger_storage:
    backends:
      some_storage:
        elasticsearch:
          index_prefix: "jaeger-main"
      another_storage:
        elasticsearch:
          index_prefix: "jaeger-archive"

The following ports can also be used by jaeger for various types of integrations:

PortProtocolEndpointFunction
4317gRPCn/aAccepts traces in OpenTelemetry OTLP formatexternal link (Protobuf).
4318HTTP/v1/tracesAccepts traces in OpenTelemetry OTLP formatexternal link (Protobuf and JSON).
14268HTTP/api/samplingServes sampling policies (see Remote Sampling).
/api/tracesAccepts spans in jaeger.thriftexternal link format with binary thrift protocol (POST).
8888HTTP/Prometheus-style metrics (GET).
9411HTTP/api/v1/spans and /api/v2/spansAccepts Zipkin spans in Thrift, JSON and Proto (disabled by default).

Clock Skew Adjustment

Jaeger backend combines trace data from applications that are usually running on different hosts. The hardware clocks on the hosts often experience relative drift, known as the clock skew effectexternal link. Clock skew can make it difficult to reason about traces, for example, when a server span may appear to start earlier than the client span, which should not be possible. jaeger query extension implements a clock skew adjustment algorithm (codeexternal link) to correct for clock drift, using the knowledge about causal relationships between spans. All adjusted spans have a warning displayed in the UI that provides the exact clock skew delta applied to their timestamps.

Sometimes these adjustments themselves make the trace hard to understand. For example, when repositioning the server span within the bounds of its parent span, Jaeger does not know the exact relationship between the request and response latencies, so it assumes they are equal and places the child span in the middle of the parent span (see issue #961external link).

jaeger query extension supports configuration in the config file

query:
  max-clock-skew-adjustment: 30s

that controls how much clock skew adjustment should be allowed. Setting this parameter to zero (0s) disables clock skew adjustment completely. This setting applies to all traces retrieved from the given query service. There is an open ticket #197external link to support toggling the adjustment on and off directly in the UI.

UI Base Path

The base path for all jaeger query extension HTTP routes can be set to a non-root value, e.g. /jaeger would cause all UI URLs to start with /jaeger. This can be useful when running jaeger behind a reverse proxy. Here is example code to set the base path.

query:
  base-path: /
  static-files: /go/bin/jaeger-ui-build/build
  ui-config: /etc/jaeger/ui-config.json
  grpc-server:
    host-port: 0.0.0.0:16685
  http-server:
    host-port: 0.0.0.0:16686

UI Customization and Embedding

Please refer to the dedicated Frontend/UI page.

Aggregation Jobs for Service Dependencies

Production deployments need an external process that aggregates data and creates dependency links between services. Project spark-dependenciesexternal link is a Spark job which derives dependency links and writes them directly to the storage.