OpenTracing (Deprecated in v5.0.0)
OpenTracing support has been deprecated from v5.0.0 of F5 NGINX Ingress Controller.
Learn how to use OpenTracing with F5 NGINX Ingress Controller.
NGINX Ingress Controller supports OpenTracing with the third-party module opentracing-contrib/nginx-opentracing.
- 
Use a NGINX Ingress Controller image that contains OpenTracing. - You can find the images that include OpenTracing listed in the technical specs doc.
- Alternatively, you follow Build NGINX Ingress Controller using debian-image(oralpine-image) for NGINX ordebian-image-plus(oralpine-image-plus) for NGINX Plus.
- Jaeger, Zipkin and Datadog tracers are installed by default.
 
- 
Enable snippets annotations by setting the enable-snippetscommand-line argument to true.
- 
Load the OpenTracing module. You need to load the module with the configuration for the chosen tracer using the following ConfigMap keys: - opentracing-tracer: sets the path to the vendor tracer binary plugin. This is the path you used in the COPY line of step ii above.
- opentracing-tracer-config: sets the tracer configuration in JSON format.
 The following example shows how to use these two keys to load the module with Jaeger tracer: opentracing-tracer: "/usr/local/lib/libjaegertracing_plugin.so" opentracing-tracer-config: | { "service_name": "nginx-ingress", "propagation_format": "w3c", "sampler": { "type": "const", "param": 1 }, "reporter": { "localAgentHostPort": "jaeger-agent.default.svc.cluster.local:6831" } }
To enable OpenTracing globally (for all Ingress, VirtualServer and VirtualServerRoute resources), set the opentracing ConfigMap key to True:
opentracing: TrueYou can use annotations to enable or disable OpenTracing for a specific Ingress resource. As mentioned in the prerequisites section, both opentracing-tracer and opentracing-tracer-config must be configured.
Consider the following two cases:
- 
To enable OpenTracing for a specific Ingress resource, use the server snippet annotation: nginx.org/server-snippets: | opentracing on;
- 
To enable OpenTracing for specific paths: - 
You need to use Mergeable Ingress resources 
- 
You need to use the location snippets annotation to enable OpenTracing for the paths of a specific Minion Ingress resource: nginx.org/location-snippets: | opentracing on;
 
- 
- 
To disable OpenTracing for a specific Ingress resource, use the server snippet annotation: nginx.org/server-snippets: | opentracing off;
- 
To disable OpenTracing for specific paths: - 
You need to use Mergeable Ingress resources 
- 
You need to use the location snippets annotation to disable OpenTracing for the paths of a specific Minion Ingress resource: nginx.org/location-snippets: | opentracing off;
 
- 
You can customize OpenTracing through the supported OpenTracing module directives. Use the location-snippets ConfigMap keys or annotations to insert those directives into the generated NGINX configuration.
For example, to propagate the active span context for upstream requests, you need to set the opentracing_propagate_context directive, which you can add to an Ingress resource using the location snippets annotation:
nginx.org/location-snippets: |
   opentracing_propagate_context;   Note: Theopentracing_propagate_contextandopentracing_grpc_propagate_contextdirectives can be used inhttp,serverorlocationcontexts according to the module documentation. However, because of the way the module works and how NGINX Ingress Controller generates the NGINX configuration, it is only possible to use the directive in thelocationcontext.