Dieser Inhalt ist in der von Ihnen ausgewählten Sprache nicht verfügbar.
Chapter 12. Migrating
The deprecated Red Hat OpenShift Distributed Tracing Platform (Jaeger) 3.5 was the last release of the Red Hat OpenShift Distributed Tracing Platform (Jaeger) that Red Hat supports.
Support for the deprecated Red Hat OpenShift Distributed Tracing Platform (Jaeger) ends on November 3, 2025.
				The Red Hat OpenShift Distributed Tracing Platform Operator (Jaeger) will be removed from the redhat-operators catalog on November 3, 2025. For more information, see the Red Hat Knowledgebase solution Jaeger Deprecation and Removal in OpenShift.
			
You must migrate to the Red Hat build of OpenTelemetry Operator and the Tempo Operator for distributed tracing collection and storage. For more information, see "Migrating" in the Red Hat build of OpenTelemetry documentation, "Installing" in the Red Hat build of OpenTelemetry documentation, and "Installing" in the Distributed Tracing Platform documentation.
If you are already using the Red Hat OpenShift Distributed Tracing Platform (Jaeger) for your applications, you can migrate to the Red Hat build of OpenTelemetry, which is based on the OpenTelemetry open-source project.
The Red Hat build of OpenTelemetry provides a set of APIs, libraries, agents, and instrumentation to facilitate observability in distributed systems. The OpenTelemetry Collector in the Red Hat build of OpenTelemetry can ingest the Jaeger protocol, so you do not need to change the SDKs in your applications.
Migration from the Distributed Tracing Platform (Jaeger) to the Red Hat build of OpenTelemetry requires configuring the OpenTelemetry Collector and your applications to report traces seamlessly. You can migrate sidecar and sidecarless deployments.
12.1. Migrating with sidecars
The Red Hat build of OpenTelemetry Operator supports sidecar injection into deployment workloads, so you can migrate from a Distributed Tracing Platform (Jaeger) sidecar to a Red Hat build of OpenTelemetry sidecar.
Prerequisites
- The Red Hat OpenShift Distributed Tracing Platform (Jaeger) is used on the cluster.
- The Red Hat build of OpenTelemetry is installed.
Procedure
- Configure the OpenTelemetry Collector as a sidecar. - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- This endpoint points to the Gateway of a TempoStack instance deployed by using the<example>Tempo Operator.
 
- Create a service account for running your application. - apiVersion: v1 kind: ServiceAccount metadata: name: otel-collector-sidecar - apiVersion: v1 kind: ServiceAccount metadata: name: otel-collector-sidecar- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Create a cluster role for the permissions needed by some processors. - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- Theresourcedetectionprocessorrequires permissions for infrastructures and infrastructures/status.
 
- Create a - ClusterRoleBindingto set the permissions for the service account.- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Deploy the OpenTelemetry Collector as a sidecar.
- 
						Remove the injected Jaeger Agent from your application by removing the "sidecar.jaegertracing.io/inject": "true"annotation from yourDeploymentobject.
- 
						Enable automatic injection of the OpenTelemetry sidecar by adding the sidecar.opentelemetry.io/inject: "true"annotation to the.spec.template.metadata.annotationsfield of yourDeploymentobject.
- Use the created service account for the deployment of your application to allow the processors to get the correct information and add it to your traces.
12.2. Migrating without sidecars
You can migrate from the Distributed Tracing Platform (Jaeger) to the Red Hat build of OpenTelemetry without sidecar deployment.
Prerequisites
- The Red Hat OpenShift Distributed Tracing Platform (Jaeger) is used on the cluster.
- The Red Hat build of OpenTelemetry is installed.
Procedure
- Configure OpenTelemetry Collector deployment.
- Create the project where the OpenTelemetry Collector will be deployed. - apiVersion: project.openshift.io/v1 kind: Project metadata: name: observability - apiVersion: project.openshift.io/v1 kind: Project metadata: name: observability- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Create a service account for running the OpenTelemetry Collector instance. - apiVersion: v1 kind: ServiceAccount metadata: name: otel-collector-deployment namespace: observability - apiVersion: v1 kind: ServiceAccount metadata: name: otel-collector-deployment namespace: observability- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Create a cluster role for setting the required permissions for the processors. - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Create a ClusterRoleBinding to set the permissions for the service account. - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Create the OpenTelemetry Collector instance. Note- This collector will export traces to a TempoStack instance. You must create your TempoStack instance by using the Red Hat Tempo Operator and place here the correct endpoint. - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Point your tracing endpoint to the OpenTelemetry Operator.
- If you are exporting your traces directly from your application to Jaeger, change the API endpoint from the Jaeger endpoint to the OpenTelemetry Collector endpoint. - Example of exporting traces by using the - jaegerexporterwith Golang- exp, err := jaeger.New(jaeger.WithCollectorEndpoint(jaeger.WithEndpoint(url))) - exp, err := jaeger.New(jaeger.WithCollectorEndpoint(jaeger.WithEndpoint(url)))- 1 - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- The URL points to the OpenTelemetry Collector API endpoint.