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

Kafka


  • Supported Kafka versions: 3.x

Kafka can be used as an intermediary buffer between collector and an actual storage. Jaeger can be configured to act both as the collector that exports trace data into a Kafka topic as well as the ingester to read data from Kafka and write it to a storage backend.

flowchart LR A(Application) --> C@{ shape: procs, label: "Jaeger collectors"} C --> K@{ img: "/img/kafka.png", w: 120, h: 60 } K --> I@{ shape: procs, label: "Jaeger ingesters"} I --> S[(Storage)] style C fill:#9AEBFE,color:black style I fill:#9AEBFE,color:black

Writing to Kafka is particularly useful for building post-processing data pipelines.

flowchart LR A(Application) --> C@{ shape: procs, label: "Jaeger collectors"} C --> K@{ img: "/img/kafka.png", w: 120, h: 60 } K --> I@{ shape: procs, label: "Jaeger ingesters"} I --> S[(Storage)] K --> P@{ shape: stadium, label: "Post-processing" } style C fill:#9AEBFE,color:black style I fill:#9AEBFE,color:black

Kafka also has the following officially supported resources available from the community:

Configuration

Please refer to these sample configuration files:

Jaeger uses Kafka exporter and receiver from opentelemetry-collector-contrib repository. Please refer to their respective README’s for configuration details.

Topic & partitions

Unless your Kafka cluster is configured to automatically create topics, you will need to create it ahead of time. You can refer to the Kafka quickstart documentationexternal link to learn how.

You can find more information about topics and partitions in general in the official documentationexternal link. This articleexternal link provide more details about how to choose the number of partitions.