Tracer

Camel’s tracer is used for logging message details during routing, where you can see the route path of each message as they happen. Details of the message is also logged such as the message body.

There is an alternative tracer that captures the messages in a Backlog Tracer.

Enabling Tracing

In Java you set tracing on CamelContext:

context.setTracing(true);

And in XML DSL:

<camelContext trace="true" xmlns="http://activemq.apache.org/camel/schema/spring">
...
</camelContext>

And in Spring Boot

camel.springboot.tracing = true

Setting Tracing in Standby mode

By default Camel optimizes and opt-out tracing. Therefore, you would either have to enable tracing from the startup, or turn on standby mode, to allow tracing to be enabled later during runtime.

To set tracing in standby mode you can do:

context.setTracingStandby(true);

And in XML DSL:

<camelContext trace="standby" xmlns="http://activemq.apache.org/camel/schema/spring">
...
</camelContext>

And in Spring Boot

camel.springboot.tracing-standby = true

If tracer is in standby mode, then tracing is made available, and can be enabled during runtime. This requires to either use JMX or enable via Java code:

Tracer tracer = context.getTracer();
tracer.setEnabled(true);

Trace Logging Formatting

The tracer formats the execution of exchanges to log lines. They are logged at INFO level in the log category: org.apache.camel.Tracing.

The message information from the Exchange is formatted using ExchangeFormatter and the default implementation has many options you can configure accordingly to the javadoc.

The tracer outputs the logging with a prefix with the following information:

  • arrow - (direction whether input or output)

  • routeId - the current route

  • label - the current EIP node

This output is assembled using the following default format:

  • %-4.4s [%-12.12s] [%-33.33s]

The default format can be customized using, for exameple to use wider columns:

context.setTracingLoggingFormat("%-4.4s [%-30.30s] [%-50.50s]");

And in XML DSL:

<camelContext trace="true" traceLoggingFormat="%-4.4s [%-30.30s] [%-50.50s]">
...
</camelContext>

And in Spring Boot

camel.springboot.tracing-logging-format = %-4.4s [%-30.30s] [%-50.50s]

And in Camel Main / Quarkus

camel.main.tracing-logging-format = %-4.4s [%-30.30s] [%-50.50s]