Available as of Camel 2.18
The camel-zipkin component is used for tracing and timing incoming and outgoing Camel messages using zipkin.
Events (span) are captured for incoming and outgoing messages being sent to/from Camel.
This means you need to configure which which Camel endpoints that maps to zipkin service names.
The mapping can be configured using:
- route id - A Camel route id
- endpoint url - A Camel endpoint url
For both kinds you can use wildcards and regular expressions to match, which is using the rules from Intercept.
To match all Camel messages you can use * in the pattern and configure that to the same service name.
If no mapping has been configured then Camel will fallback and use endpoint uri's as service names.
However its recommended to configure service mappings so you can use human logic names instead of Camel endpoint uris in the names.
Camel will auto-configure a ScribeSpanCollector if no SpanCollector explicit has been configured, and if the hostname and port has been configured as environment variables
- ZIPKIN_SERVICE_HOST - The hostname
- ZIPKIN_SERVICE_PORT - The port number
This makes it easy to use camel-zipkin in container platforms where the platform can run your application in a linux container where service configurations are provided as environment variables.
Configuration
To enable camel-zipkin you need to configure first
ZipkinEventNotifier zipkin = new ZipkinEventNotifier(); // configure the scribe span collector with the hostname and port for the Zipkin Collector Server zipkin.setSpanCollector(new ScribeSpanCollector("192.168.90.100, 9410); // and then add zipkin as event notifier camelContext.getManagementStrategy().addEventNotifier(zipkin);
The configuration about will the trace all incoming and outgoing messages in Camel routes.
However if you want to map Camel endpoints to human friendly logical names, you can add mappings such as:
zipkin.addServiceMapping("activemq:queue:invoice", "invoices"); zipkin.addServiceMapping("http:legacy.server.com*", "old-junk");
Options
You can configure the following options on ZipkinEventNotifier
Option | Default | Description |
---|---|---|
rate | 1.0f | Configures a rate that decides how many events should be traced by zipkin. The rate is expressed as a percentage (1.0f = 100%, 0.5f is 50%, 0.1f is 10%). |
spanCollector | The collector to use for sending zipkin span events to the zipkin server. | |
serviceName | To use a global service name that matches all Camel events | |
serviceMappings | Sets the service mappings that matches Camel events to the given zipkin service name. | |
excludePatterns | Sets exclude pattern(s) that will disable tracing with zipkin for Camel messages that matches the pattern. | |
includeMessageBody | false | Whether to include the Camel message body in the zipkin traces. This is not recommended for production usage, or when having big payloads. You can limit the size by configuring the max debug log size. |