Search code examples
istiojaeger

How to configure istio-proxy to log traceId?


I am using istio with version 1.3.5. Is there any configuration to be set to allow istio-proxy to log traceId? I am using jaeger tracing (wit zipkin protocol) being enabled. There is one thing I want to accomplish by having traceId logging: - log correlation in multiple services upstream. Basically I can filter all logs by certain traceId.


Solution

  • According to envoy proxy documentation for envoy v1.12.0 used by istio 1.3:

    Trace context propagation

    Envoy provides the capability for reporting tracing information regarding communications between services in the mesh. However, to be able to correlate the pieces of tracing information generated by the various proxies within a call flow, the services must propagate certain trace context between the inbound and outbound requests.

    Whichever tracing provider is being used, the service should propagate the x-request-id to enable logging across the invoked services to be correlated.

    The tracing providers also require additional context, to enable the parent/child relationships between the spans (logical units of work) to be understood. This can be achieved by using the LightStep (via OpenTracing API) or Zipkin tracer directly within the service itself, to extract the trace context from the inbound request and inject it into any subsequent outbound requests. This approach would also enable the service to create additional spans, describing work being done internally within the service, that may be useful when examining the end-to-end trace.

    Alternatively the trace context can be manually propagated by the service:


    TLDR: traceId headers need to be manually added to B3 HTTP headers.

    Additional information: https://github.com/openzipkin/b3-propagation