This documentation is for a release that is no longer maintained
See documentation for the latest supported version 3 or the latest supported version 4.Este conteúdo não está disponível no idioma selecionado.
Chapter 3. Distributed tracing platform (Jaeger)
3.1. Installing the distributed tracing platform Jaeger
Jaeger is deprecated in Red Hat OpenShift distributed tracing 3.0.
You can install Red Hat OpenShift distributed tracing platform on OpenShift Container Platform in either of two ways:
- 
						You can install Red Hat OpenShift distributed tracing platform as part of Red Hat OpenShift Service Mesh. Distributed tracing is included by default in the Service Mesh installation. To install Red Hat OpenShift distributed tracing platform as part of a service mesh, follow the Red Hat Service Mesh Installation instructions. You must install Red Hat OpenShift distributed tracing platform in the same namespace as your service mesh, that is, the ServiceMeshControlPlaneand the Red Hat OpenShift distributed tracing platform resources must be in the same namespace.
- If you do not want to install a service mesh, you can use the Red Hat OpenShift distributed tracing platform Operators to install distributed tracing platform by itself. To install Red Hat OpenShift distributed tracing platform without a service mesh, use the following instructions.
3.1.1. Prerequisites
Before you can install Red Hat OpenShift distributed tracing platform, review the installation activities, and ensure that you meet the prerequisites:
- Possess an active OpenShift Container Platform subscription on your Red Hat account. If you do not have a subscription, contact your sales representative for more information.
- Review the OpenShift Container Platform 4.11 overview.
- Install OpenShift Container Platform 4.11. 
- 
							Install the version of the ocCLI tool that matches your OpenShift Container Platform version and add it to your path.
- 
							An account with the cluster-adminrole.
3.1.2. Red Hat OpenShift distributed tracing platform installation overview
The steps for installing Red Hat OpenShift distributed tracing platform are as follows:
- Review the documentation and determine your deployment strategy.
- If your deployment strategy requires persistent storage, install the OpenShift Elasticsearch Operator via the OperatorHub.
- Install the Red Hat OpenShift distributed tracing platform (Jaeger) Operator via the OperatorHub.
- Modify the custom resource YAML file to support your deployment strategy.
- Deploy one or more instances of Red Hat OpenShift distributed tracing platform (Jaeger) to your OpenShift Container Platform environment.
3.1.3. Installing the OpenShift Elasticsearch Operator
The default Red Hat OpenShift distributed tracing platform (Jaeger) deployment uses in-memory storage because it is designed to be installed quickly for those evaluating Red Hat OpenShift distributed tracing platform, giving demonstrations, or using Red Hat OpenShift distributed tracing platform (Jaeger) in a test environment. If you plan to use Red Hat OpenShift distributed tracing platform (Jaeger) in production, you must install and configure a persistent storage option, in this case, Elasticsearch.
Prerequisites
- You have access to the OpenShift Container Platform web console.
- 
							You have access to the cluster as a user with the cluster-adminrole. If you use Red Hat OpenShift Dedicated, you must have an account with thededicated-adminrole.
Do not install Community versions of the Operators. Community Operators are not supported.
If you have already installed the OpenShift Elasticsearch Operator as part of OpenShift Logging, you do not need to install the OpenShift Elasticsearch Operator again. The Red Hat OpenShift distributed tracing platform (Jaeger) Operator creates the Elasticsearch instance using the installed OpenShift Elasticsearch Operator.
Procedure
- 
							Log in to the OpenShift Container Platform web console as a user with the cluster-adminrole. If you use Red Hat OpenShift Dedicated, you must have an account with thededicated-adminrole.
- 
							Navigate to Operators OperatorHub. 
- Type Elasticsearch into the filter box to locate the OpenShift Elasticsearch Operator.
- Click the OpenShift Elasticsearch Operator provided by Red Hat to display information about the Operator.
- Click Install.
- On the Install Operator page, select the stable Update Channel. This automatically updates your Operator as new versions are released.
- Accept the default All namespaces on the cluster (default). This installs the Operator in the default - openshift-operators-redhatproject and makes the Operator available to all projects in the cluster.Note- The Elasticsearch installation requires the openshift-operators-redhat namespace for the OpenShift Elasticsearch Operator. The other Red Hat OpenShift distributed tracing platform Operators are installed in the - openshift-operatorsnamespace.
- Accept the default Automatic approval strategy. By accepting the default, when a new version of this Operator is available, Operator Lifecycle Manager (OLM) automatically upgrades the running instance of your Operator without human intervention. If you select Manual updates, when a newer version of an Operator is available, OLM creates an update request. As a cluster administrator, you must then manually approve that update request to have the Operator updated to the new version. Note- The Manual approval strategy requires a user with appropriate credentials to approve the Operator install and subscription process. 
- Click Install.
- 
							On the Installed Operators page, select the openshift-operators-redhatproject. Wait until you see that the OpenShift Elasticsearch Operator shows a status of "InstallSucceeded" before continuing.
3.1.4. Installing the Red Hat OpenShift distributed tracing platform (Jaeger) Operator
To install Red Hat OpenShift distributed tracing platform (Jaeger), you use the OperatorHub to install the Red Hat OpenShift distributed tracing platform (Jaeger) Operator.
					By default, the Operator is installed in the openshift-operators project.
				
Prerequisites
- You have access to the OpenShift Container Platform web console.
- 
							You have access to the cluster as a user with the cluster-adminrole. If you use Red Hat OpenShift Dedicated, you must have an account with thededicated-adminrole.
- If you require persistent storage, you must also install the OpenShift Elasticsearch Operator before installing the Red Hat OpenShift distributed tracing platform (Jaeger) Operator.
Do not install Community versions of the Operators. Community Operators are not supported.
Procedure
- 
							Log in to the OpenShift Container Platform web console as a user with the cluster-adminrole. If you use Red Hat OpenShift Dedicated, you must have an account with thededicated-adminrole.
- 
							Navigate to Operators OperatorHub. 
- Type distributed tracing platform into the filter to locate the Red Hat OpenShift distributed tracing platform (Jaeger) Operator.
- Click the Red Hat OpenShift distributed tracing platform (Jaeger) Operator provided by Red Hat to display information about the Operator.
- Click Install.
- On the Install Operator page, select the stable Update Channel. This automatically updates your Operator as new versions are released.
- Accept the default All namespaces on the cluster (default). This installs the Operator in the default - openshift-operatorsproject and makes the Operator available to all projects in the cluster.- Accept the default Automatic approval strategy. By accepting the default, when a new version of this Operator is available, Operator Lifecycle Manager (OLM) automatically upgrades the running instance of your Operator without human intervention. If you select Manual updates, when a newer version of an Operator is available, OLM creates an update request. As a cluster administrator, you must then manually approve that update request to have the Operator updated to the new version. Note- The Manual approval strategy requires a user with appropriate credentials to approve the Operator install and subscription process. 
 
- Click Install.
- 
							Navigate to Operators Installed Operators. 
- 
							On the Installed Operators page, select the openshift-operatorsproject. Wait until you see that the Red Hat OpenShift distributed tracing platform (Jaeger) Operator shows a status of "Succeeded" before continuing.
3.2. Configuring and deploying the distributed tracing platform Jaeger
The Red Hat OpenShift distributed tracing platform (Jaeger) Operator uses a custom resource definition (CRD) file that defines the architecture and configuration settings to be used when creating and deploying the distributed tracing platform (Jaeger) resources. You can install the default configuration or modify the file.
If you have installed distributed tracing platform as part of Red Hat OpenShift Service Mesh, you can perform basic configuration as part of the ServiceMeshControlPlane, but for complete control, you must configure a Jaeger CR and then reference your distributed tracing configuration file in the ServiceMeshControlPlane.
The Red Hat OpenShift distributed tracing platform (Jaeger) has predefined deployment strategies. You specify a deployment strategy in the custom resource file. When you create a distributed tracing platform (Jaeger) instance, the Operator uses this configuration file to create the objects necessary for the deployment.
Jaeger custom resource file showing deployment strategy
- 1
- Deployment strategy.
3.2.1. Supported deployment strategies
The Red Hat OpenShift distributed tracing platform (Jaeger) Operator currently supports the following deployment strategies:
- allInOne
- - This strategy is intended for development, testing, and demo purposes; it is not intended for production use. The main backend components, Agent, Collector, and Query service, are all packaged into a single executable which is configured, by default. to use in-memory storage. Note- In-memory storage is not persistent, which means that if the distributed tracing platform (Jaeger) instance shuts down, restarts, or is replaced, that your trace data will be lost. And in-memory storage cannot be scaled, since each pod has its own memory. For persistent storage, you must use the - productionor- streamingstrategies, which use Elasticsearch as the default storage.
- production
- The production strategy is intended for production environments, where long term storage of trace data is important, as well as a more scalable and highly available architecture is required. Each of the backend components is therefore deployed separately. The Agent can be injected as a sidecar on the instrumented application. The Query and Collector services are configured with a supported storage type - currently Elasticsearch. Multiple instances of each of these components can be provisioned as required for performance and resilience purposes.
- streaming
- The streaming strategy is designed to augment the production strategy by providing a streaming capability that effectively sits between the Collector and the Elasticsearch backend storage. This provides the benefit of reducing the pressure on the backend storage, under high load situations, and enables other trace post-processing capabilities to tap into the real time span data directly from the streaming platform (AMQ Streams/ Kafka). Note- The streaming strategy requires an additional Red Hat subscription for AMQ Streams.
- The streaming deployment strategy is currently unsupported on IBM Z.
 
3.2.2. Deploying the distributed tracing platform default strategy from the web console
					The custom resource definition (CRD) defines the configuration used when you deploy an instance of Red Hat OpenShift distributed tracing platform. The default CR is named jaeger-all-in-one-inmemory and it is configured with minimal resources to ensure that you can successfully install it on a default OpenShift Container Platform installation. You can use this default configuration to create a Red Hat OpenShift distributed tracing platform (Jaeger) instance that uses the AllInOne deployment strategy, or you can define your own custom resource file.
				
						In-memory storage is not persistent. If the Jaeger pod shuts down, restarts, or is replaced, your trace data will be lost. For persistent storage, you must use the production or streaming strategies, which use Elasticsearch as the default storage.
					
Prerequisites
- The Red Hat OpenShift distributed tracing platform (Jaeger) Operator has been installed.
- You have reviewed the instructions for how to customize the deployment.
- 
							You have access to the cluster as a user with the cluster-adminrole.
Procedure
- 
							Log in to the OpenShift Container Platform web console as a user with the cluster-adminrole.
- Create a new project, for example - tracing-system.Note- If you are installing as part of Service Mesh, the distributed tracing platform resources must be installed in the same namespace as the - ServiceMeshControlPlaneresource, for example- istio-system.- 
									Go to Home Projects. 
- Click Create Project.
- 
									Enter tracing-systemin the Name field.
- Click Create.
 
- 
									Go to Home 
- 
							Navigate to Operators Installed Operators. 
- 
							If necessary, select tracing-systemfrom the Project menu. You may have to wait a few moments for the Operators to be copied to the new project.
- Click the Red Hat OpenShift distributed tracing platform (Jaeger) Operator. On the Details tab, under Provided APIs, the Operator provides a single link.
- Under Jaeger, click Create Instance.
- On the Create Jaeger page, to install using the defaults, click Create to create the distributed tracing platform (Jaeger) instance.
- 
							On the Jaegers page, click the name of the distributed tracing platform (Jaeger) instance, for example, jaeger-all-in-one-inmemory.
- On the Jaeger Details page, click the Resources tab. Wait until the pod has a status of "Running" before continuing.
3.2.2.1. Deploying the distributed tracing platform default strategy from the CLI
Follow this procedure to create an instance of distributed tracing platform (Jaeger) from the command line.
Prerequisites
- The Red Hat OpenShift distributed tracing platform (Jaeger) Operator has been installed and verified.
- You have reviewed the instructions for how to customize the deployment.
- 
								You have access to the OpenShift CLI (oc) that matches your OpenShift Container Platform version.
- 
								You have access to the cluster as a user with the cluster-adminrole.
Procedure
- Log in to the OpenShift Container Platform CLI as a user with the - cluster-adminrole by running the following command:- oc login --username=<NAMEOFUSER> https://<HOSTNAME>:8443 - $ oc login --username=<NAMEOFUSER> https://<HOSTNAME>:8443- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Create a new project named - tracing-systemby running the following command:- oc new-project tracing-system - $ oc new-project tracing-system- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Create a custom resource file named - jaeger.yamlthat contains the following text:- Example jaeger-all-in-one.yaml - apiVersion: jaegertracing.io/v1 kind: Jaeger metadata: name: jaeger-all-in-one-inmemory - apiVersion: jaegertracing.io/v1 kind: Jaeger metadata: name: jaeger-all-in-one-inmemory- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Run the following command to deploy distributed tracing platform (Jaeger): - oc create -n tracing-system -f jaeger.yaml - $ oc create -n tracing-system -f jaeger.yaml- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Run the following command to watch the progress of the pods during the installation process: - oc get pods -n tracing-system -w - $ oc get pods -n tracing-system -w- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - After the installation process has completed, the output is similar to the following example: - NAME READY STATUS RESTARTS AGE jaeger-all-in-one-inmemory-cdff7897b-qhfdx 2/2 Running 0 24s - NAME READY STATUS RESTARTS AGE jaeger-all-in-one-inmemory-cdff7897b-qhfdx 2/2 Running 0 24s- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
3.2.3. Deploying the distributed tracing platform production strategy from the web console
					The production deployment strategy is intended for production environments that require a more scalable and highly available architecture, and where long-term storage of trace data is important.
				
Prerequisites
- The OpenShift Elasticsearch Operator has been installed.
- The Red Hat OpenShift distributed tracing platform (Jaeger) Operator has been installed.
- You have reviewed the instructions for how to customize the deployment.
- 
							You have access to the cluster as a user with the cluster-adminrole.
Procedure
- 
							Log in to the OpenShift Container Platform web console as a user with the cluster-adminrole.
- Create a new project, for example - tracing-system.Note- If you are installing as part of Service Mesh, the distributed tracing platform resources must be installed in the same namespace as the - ServiceMeshControlPlaneresource, for example- istio-system.- 
									Navigate to Home Projects. 
- Click Create Project.
- 
									Enter tracing-systemin the Name field.
- Click Create.
 
- 
									Navigate to Home 
- 
							Navigate to Operators Installed Operators. 
- 
							If necessary, select tracing-systemfrom the Project menu. You may have to wait a few moments for the Operators to be copied to the new project.
- Click the Red Hat OpenShift distributed tracing platform (Jaeger) Operator. On the Overview tab, under Provided APIs, the Operator provides a single link.
- Under Jaeger, click Create Instance.
- On the Create Jaeger page, replace the default - all-in-oneYAML text with your production YAML configuration, for example:- Example jaeger-production.yaml file with Elasticsearch - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Click Create to create the distributed tracing platform (Jaeger) instance.
- 
							On the Jaegers page, click the name of the distributed tracing platform (Jaeger) instance, for example, jaeger-prod-elasticsearch.
- On the Jaeger Details page, click the Resources tab. Wait until all the pods have a status of "Running" before continuing.
3.2.3.1. Deploying the distributed tracing platform production strategy from the CLI
Follow this procedure to create an instance of distributed tracing platform (Jaeger) from the command line.
Prerequisites
- The OpenShift Elasticsearch Operator has been installed.
- The Red Hat OpenShift distributed tracing platform (Jaeger) Operator has been installed.
- You have reviewed the instructions for how to customize the deployment.
- 
								You have access to the OpenShift CLI (oc) that matches your OpenShift Container Platform version.
- 
								You have access to the cluster as a user with the cluster-adminrole.
Procedure
- Log in to the OpenShift CLI ( - oc) as a user with the- cluster-adminrole by running the following command:- oc login --username=<NAMEOFUSER> https://<HOSTNAME>:8443 - $ oc login --username=<NAMEOFUSER> https://<HOSTNAME>:8443- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Create a new project named - tracing-systemby running the following command:- oc new-project tracing-system - $ oc new-project tracing-system- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- 
								Create a custom resource file named jaeger-production.yamlthat contains the text of the example file in the previous procedure.
- Run the following command to deploy distributed tracing platform (Jaeger): - oc create -n tracing-system -f jaeger-production.yaml - $ oc create -n tracing-system -f jaeger-production.yaml- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Run the following command to watch the progress of the pods during the installation process: - oc get pods -n tracing-system -w - $ oc get pods -n tracing-system -w- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - After the installation process has completed, you will see output similar to the following example: - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
3.2.4. Deploying the distributed tracing platform streaming strategy from the web console
					The streaming deployment strategy is intended for production environments that require a more scalable and highly available architecture, and where long-term storage of trace data is important.
				
					The streaming strategy provides a streaming capability that sits between the Collector and the Elasticsearch storage. This reduces the pressure on the storage under high load situations, and enables other trace post-processing capabilities to tap into the real-time span data directly from the Kafka streaming platform.
				
The streaming strategy requires an additional Red Hat subscription for AMQ Streams. If you do not have an AMQ Streams subscription, contact your sales representative for more information.
The streaming deployment strategy is currently unsupported on IBM Z.
Prerequisites
- The AMQ Streams Operator has been installed. If using version 1.4.0 or higher you can use self-provisioning. Otherwise you must create the Kafka instance.
- The Red Hat OpenShift distributed tracing platform (Jaeger) Operator has been installed.
- You have reviewed the instructions for how to customize the deployment.
- 
							You have access to the cluster as a user with the cluster-adminrole.
Procedure
- 
							Log in to the OpenShift Container Platform web console as a user with the cluster-adminrole.
- Create a new project, for example - tracing-system.Note- If you are installing as part of Service Mesh, the distributed tracing platform resources must be installed in the same namespace as the - ServiceMeshControlPlaneresource, for example- istio-system.- 
									Navigate to Home Projects. 
- Click Create Project.
- 
									Enter tracing-systemin the Name field.
- Click Create.
 
- 
									Navigate to Home 
- 
							Navigate to Operators Installed Operators. 
- 
							If necessary, select tracing-systemfrom the Project menu. You may have to wait a few moments for the Operators to be copied to the new project.
- Click the Red Hat OpenShift distributed tracing platform (Jaeger) Operator. On the Overview tab, under Provided APIs, the Operator provides a single link.
- Under Jaeger, click Create Instance.
- On the Create Jaeger page, replace the default - all-in-oneYAML text with your streaming YAML configuration, for example:- Example jaeger-streaming.yaml file - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- If the brokers are not defined, AMQStreams 1.4.0+ self-provisions Kafka.
 
- Click Create to create the distributed tracing platform (Jaeger) instance.
- 
							On the Jaegers page, click the name of the distributed tracing platform (Jaeger) instance, for example, jaeger-streaming.
- On the Jaeger Details page, click the Resources tab. Wait until all the pods have a status of "Running" before continuing.
3.2.4.1. Deploying the distributed tracing platform streaming strategy from the CLI
Follow this procedure to create an instance of distributed tracing platform (Jaeger) from the command line.
Prerequisites
- The AMQ Streams Operator has been installed. If using version 1.4.0 or higher you can use self-provisioning. Otherwise you must create the Kafka instance.
- The Red Hat OpenShift distributed tracing platform (Jaeger) Operator has been installed.
- You have reviewed the instructions for how to customize the deployment.
- 
								You have access to the OpenShift CLI (oc) that matches your OpenShift Container Platform version.
- 
								You have access to the cluster as a user with the cluster-adminrole.
Procedure
- Log in to the OpenShift CLI ( - oc) as a user with the- cluster-adminrole by running the following command:- oc login --username=<NAMEOFUSER> https://<HOSTNAME>:8443 - $ oc login --username=<NAMEOFUSER> https://<HOSTNAME>:8443- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Create a new project named - tracing-systemby running the following command:- oc new-project tracing-system - $ oc new-project tracing-system- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- 
								Create a custom resource file named jaeger-streaming.yamlthat contains the text of the example file in the previous procedure.
- Run the following command to deploy Jaeger: - oc create -n tracing-system -f jaeger-streaming.yaml - $ oc create -n tracing-system -f jaeger-streaming.yaml- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Run the following command to watch the progress of the pods during the installation process: - oc get pods -n tracing-system -w - $ oc get pods -n tracing-system -w- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - After the installation process has completed, you should see output similar to the following example: - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
3.2.5. Validating your deployment
3.2.5.1. Accessing the Jaeger console
To access the Jaeger console you must have either Red Hat OpenShift Service Mesh or Red Hat OpenShift distributed tracing platform installed, and Red Hat OpenShift distributed tracing platform (Jaeger) installed, configured, and deployed.
The installation process creates a route to access the Jaeger console.
If you know the URL for the Jaeger console, you can access it directly. If you do not know the URL, use the following directions.
Procedure from the web console
- 
								Log in to the OpenShift Container Platform web console as a user with cluster-admin rights. If you use Red Hat OpenShift Dedicated, you must have an account with the dedicated-adminrole.
- 
								Navigate to Networking Routes. 
- On the Routes page, select the control plane project, for example - tracing-system, from the Namespace menu.- The Location column displays the linked address for each route. 
- 
								If necessary, use the filter to find the jaegerroute. Click the route Location to launch the console.
- Click Log In With OpenShift.
Procedure from the CLI
- Log in to the OpenShift Container Platform CLI as a user with the - cluster-adminrole by running the following command. If you use Red Hat OpenShift Dedicated, you must have an account with the- dedicated-adminrole.- oc login --username=<NAMEOFUSER> https://<HOSTNAME>:6443 - $ oc login --username=<NAMEOFUSER> https://<HOSTNAME>:6443- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- To query for details of the route using the command line, enter the following command. In this example, - tracing-systemis the control plane namespace.- export JAEGER_URL=$(oc get route -n tracing-system jaeger -o jsonpath='{.spec.host}')- $ export JAEGER_URL=$(oc get route -n tracing-system jaeger -o jsonpath='{.spec.host}')- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- 
								Launch a browser and navigate to https://<JAEGER_URL>, where<JAEGER_URL>is the route that you discovered in the previous step.
- Log in using the same user name and password that you use to access the OpenShift Container Platform console.
- If you have added services to the service mesh and have generated traces, you can use the filters and Find Traces button to search your trace data. - If you are validating the console installation, there is no trace data to display. 
3.2.6. Customizing your deployment
3.2.6.1. Deployment best practices
- Red Hat OpenShift distributed tracing platform instance names must be unique. If you want to have multiple Red Hat OpenShift distributed tracing platform (Jaeger) instances and are using sidecar injected agents, then the Red Hat OpenShift distributed tracing platform (Jaeger) instances should have unique names, and the injection annotation should explicitly specify the Red Hat OpenShift distributed tracing platform (Jaeger) instance name the tracing data should be reported to.
- If you have a multitenant implementation and tenants are separated by namespaces, deploy a Red Hat OpenShift distributed tracing platform (Jaeger) instance to each tenant namespace.
For information about configuring persistent storage, see Understanding persistent storage and the appropriate configuration topic for your chosen storage option.
3.2.6.2. Distributed tracing default configuration options
The Jaeger custom resource (CR) defines the architecture and settings to be used when creating the distributed tracing platform (Jaeger) resources. You can modify these parameters to customize your distributed tracing platform (Jaeger) implementation to your business needs.
Generic YAML example of the Jaeger CR
| Parameter | Description | Values | Default value | 
|---|---|---|---|
| 
										 | API version to use when creating the object. | 
										 | 
										 | 
| 
										 | Defines the kind of Kubernetes object to create. | 
										 | |
| 
										 | 
										Data that helps uniquely identify the object, including a  | 
										OpenShift Container Platform automatically generates the  | |
| 
										 | Name for the object. | The name of your distributed tracing platform (Jaeger) instance. | 
										 | 
| 
										 | Specification for the object to be created. | 
										Contains all of the configuration parameters for your distributed tracing platform (Jaeger) instance. When a common definition for all Jaeger components is required, it is defined under the  | N/A | 
| 
										 | Jaeger deployment strategy | 
										 | 
										 | 
| 
										 | 
										Because the  | ||
| 
										 | Configuration options that define the Agent. | ||
| 
										 | Configuration options that define the Jaeger Collector. | ||
| 
										 | Configuration options that define the sampling strategies for tracing. | ||
| 
										 | 
										Configuration options that define the storage. All storage-related options must be placed under  | ||
| 
										 | Configuration options that define the Query service. | ||
| 
										 | Configuration options that define the Ingester service. | 
The following example YAML is the minimum required to create a Red Hat OpenShift distributed tracing platform (Jaeger) deployment using the default settings.
Example minimum required dist-tracing-all-in-one.yaml
apiVersion: jaegertracing.io/v1 kind: Jaeger metadata: name: jaeger-all-in-one-inmemory
apiVersion: jaegertracing.io/v1
kind: Jaeger
metadata:
  name: jaeger-all-in-one-inmemory3.2.6.3. Jaeger Collector configuration options
						The Jaeger Collector is the component responsible for receiving the spans that were captured by the tracer and writing them to persistent Elasticsearch storage when using the production strategy, or to AMQ Streams when using the streaming strategy.
					
The Collectors are stateless and thus many instances of Jaeger Collector can be run in parallel. Collectors require almost no configuration, except for the location of the Elasticsearch cluster.
| Parameter | Description | Values | 
|---|---|---|
| collector: replicas:  | Specifies the number of Collector replicas to create. | 
										Integer, for example,  | 
| Parameter | Description | Values | 
|---|---|---|
| spec:
 collector:
  options: {} | Configuration options that define the Jaeger Collector. | |
| options:
  collector:
    num-workers: | The number of workers pulling from the queue. | 
										Integer, for example,  | 
| options:
  collector:
    queue-size: | The size of the Collector queue. | 
										Integer, for example,  | 
| options:
  kafka:
    producer:
      topic: jaeger-spans | 
										The  | Label for the producer. | 
| options:
  kafka:
    producer:
      brokers: my-cluster-kafka-brokers.kafka:9092 | Identifies the Kafka configuration used by the Collector to produce the messages. If brokers are not specified, and you have AMQ Streams 1.4.0+ installed, the Red Hat OpenShift distributed tracing platform (Jaeger) Operator will self-provision Kafka. | |
| options: log-level:  | Logging level for the Collector. | 
										Possible values:  | 
|  | 
										To accept OTLP/gRPC, explicitly enable the  | options: otlp: enabled: true http: cors: allowed-headers: [<header-name>[, <header-name>]*] allowed-origins: * host-port: 4318 max-connection-age: 0s max-connection-age-grace: 0s max-message-size: 4194304 read-timeout: 0s read-header-timeout: 2s idle-timeout: 0s tls: enabled: false cert: /path/to/cert.crt cipher-suites: "TLS_AES_256_GCM_SHA384,TLS_CHACHA20_POLY1305_SHA256" client-ca: /path/to/cert.ca reload-interval: 0s min-version: 1.2 max-version: 1.3 | 
3.2.6.4. Distributed tracing sampling configuration options
The Red Hat OpenShift distributed tracing platform (Jaeger) Operator can be used to define sampling strategies that will be supplied to tracers that have been configured to use a remote sampler.
While all traces are generated, only a few are sampled. Sampling a trace marks the trace for further processing and storage.
This is not relevant if a trace was started by the Envoy proxy, as the sampling decision is made there. The Jaeger sampling decision is only relevant when the trace is started by an application using the client.
When a service receives a request that contains no trace context, the client starts a new trace, assigns it a random trace ID, and makes a sampling decision based on the currently installed sampling strategy. The sampling decision propagates to all subsequent requests in the trace so that other services are not making the sampling decision again.
distributed tracing platform (Jaeger) libraries support the following samplers:
- 
								Probabilistic - The sampler makes a random sampling decision with the probability of sampling equal to the value of the sampling.paramproperty. For example, usingsampling.param=0.1samples approximately 1 in 10 traces.
- 
								Rate Limiting - The sampler uses a leaky bucket rate limiter to ensure that traces are sampled with a certain constant rate. For example, using sampling.param=2.0samples requests with the rate of 2 traces per second.
| Parameter | Description | Values | Default value | 
|---|---|---|---|
| spec:
 sampling:
  options: {}
    default_strategy:
    service_strategy: | Configuration options that define the sampling strategies for tracing. | If you do not provide configuration, the Collectors will return the default probabilistic sampling policy with 0.001 (0.1%) probability for all services. | |
| default_strategy: type: service_strategy: type:  | Sampling strategy to use. See descriptions above. | 
										Valid values are  | 
										 | 
| default_strategy: param: service_strategy: param:  | Parameters for the selected sampling strategy. | Decimal and integer values (0, .1, 1, 10) | 1 | 
This example defines a default sampling strategy that is probabilistic, with a 50% chance of the trace instances being sampled.
Probabilistic sampling example
If there are no user-supplied configurations, the distributed tracing platform (Jaeger) uses the following settings:
Default sampling
3.2.6.5. Distributed tracing storage configuration options
						You configure storage for the Collector, Ingester, and Query services under spec.storage. Multiple instances of each of these components can be provisioned as required for performance and resilience purposes.
					
| Parameter | Description | Values | Default value | 
|---|---|---|---|
| spec:
  storage:
    type: | Type of storage to use for the deployment. | 
										 | 
										 | 
| storage: secretname:  | 
										Name of the secret, for example  | N/A | |
| storage:
  options: {} | Configuration options that define the storage. | 
| Parameter | Description | Values | Default value | 
|---|---|---|---|
| storage:
  esIndexCleaner:
    enabled: | When using Elasticsearch storage, by default a job is created to clean old traces from the index. This parameter enables or disables the index cleaner job. | 
										 | 
										 | 
| storage:
  esIndexCleaner:
    numberOfDays: | Number of days to wait before deleting an index. | Integer value | 
										 | 
| storage:
  esIndexCleaner:
    schedule: | Defines the schedule for how often to clean the Elasticsearch index. | Cron expression | "55 23 * * *" | 
3.2.6.5.1. Auto-provisioning an Elasticsearch instance
							When you deploy a Jaeger custom resource, the Red Hat OpenShift distributed tracing platform (Jaeger) Operator uses the OpenShift Elasticsearch Operator to create an Elasticsearch cluster based on the configuration provided in the storage section of the custom resource file. The Red Hat OpenShift distributed tracing platform (Jaeger) Operator will provision Elasticsearch if the following configurations are set:
						
- 
									spec.storage:typeis set toelasticsearch
- 
									spec.storage.elasticsearch.doNotProvisionset tofalse
- 
									spec.storage.options.es.server-urlsis not defined, that is, there is no connection to an Elasticsearch instance that was not provisioned by the Red Hat Elasticsearch Operator.
							When provisioning Elasticsearch, the Red Hat OpenShift distributed tracing platform (Jaeger) Operator sets the Elasticsearch custom resource name to the value of spec.storage.elasticsearch.name from the Jaeger custom resource. If you do not specify a value for spec.storage.elasticsearch.name, the Operator uses elasticsearch.
						
Restrictions
- You can have only one distributed tracing platform (Jaeger) with self-provisioned Elasticsearch instance per namespace. The Elasticsearch cluster is meant to be dedicated for a single distributed tracing platform (Jaeger) instance.
- There can be only one Elasticsearch per namespace.
If you already have installed Elasticsearch as part of OpenShift Logging, the Red Hat OpenShift distributed tracing platform (Jaeger) Operator can use the installed OpenShift Elasticsearch Operator to provision storage.
							The following configuration parameters are for a self-provisioned Elasticsearch instance, that is an instance created by the Red Hat OpenShift distributed tracing platform (Jaeger) Operator using the OpenShift Elasticsearch Operator. You specify configuration options for self-provisioned Elasticsearch under spec:storage:elasticsearch in your configuration file.
						
| Parameter | Description | Values | Default value | 
|---|---|---|---|
| elasticsearch:
  properties:
    doNotProvision: | Use to specify whether or not an Elasticsearch instance should be provisioned by the Red Hat OpenShift distributed tracing platform (Jaeger) Operator. | 
											 | 
											 | 
| elasticsearch:
  properties:
    name: | Name of the Elasticsearch instance. The Red Hat OpenShift distributed tracing platform (Jaeger) Operator uses the Elasticsearch instance specified in this parameter to connect to Elasticsearch. | string | 
											 | 
| elasticsearch: nodeCount:  | Number of Elasticsearch nodes. For high availability use at least 3 nodes. Do not use 2 nodes as “split brain” problem can happen. | Integer value. For example, Proof of concept = 1, Minimum deployment =3 | 3 | 
| elasticsearch:
  resources:
    requests:
      cpu: | Number of central processing units for requests, based on your environment’s configuration. | Specified in cores or millicores, for example, 200m, 0.5, 1. For example, Proof of concept = 500m, Minimum deployment =1 | 1 | 
| elasticsearch:
  resources:
    requests:
      memory: | Available memory for requests, based on your environment’s configuration. | Specified in bytes, for example, 200Ki, 50Mi, 5Gi. For example, Proof of concept = 1Gi, Minimum deployment = 16Gi* | 16Gi | 
| elasticsearch:
  resources:
    limits:
      cpu: | Limit on number of central processing units, based on your environment’s configuration. | Specified in cores or millicores, for example, 200m, 0.5, 1. For example, Proof of concept = 500m, Minimum deployment =1 | |
| elasticsearch:
  resources:
    limits:
      memory: | Available memory limit based on your environment’s configuration. | Specified in bytes, for example, 200Ki, 50Mi, 5Gi. For example, Proof of concept = 1Gi, Minimum deployment = 16Gi* | |
| elasticsearch: redundancyPolicy:  | Data replication policy defines how Elasticsearch shards are replicated across data nodes in the cluster. If not specified, the Red Hat OpenShift distributed tracing platform (Jaeger) Operator automatically determines the most appropriate replication based on number of nodes. | 
											 | |
| elasticsearch: useCertManagement:  | Use to specify whether or not distributed tracing platform (Jaeger) should use the certificate management feature of the Red Hat Elasticsearch Operator. This feature was added to {logging-title} 5.2 in OpenShift Container Platform 4.7 and is the preferred setting for new Jaeger deployments. | 
											 | 
											 | 
Each Elasticsearch node can operate with a lower memory setting though this is NOT recommended for production deployments. For production use, you must have no less than 16 Gi allocated to each pod by default, but preferably allocate as much as you can, up to 64 Gi per pod.
Production storage example
Storage example with persistent storage:
- 1
- Persistent storage configuration. In this case AWSgp2with5Gisize. When no value is specified, distributed tracing platform (Jaeger) usesemptyDir. The OpenShift Elasticsearch Operator provisionsPersistentVolumeClaimandPersistentVolumewhich are not removed with distributed tracing platform (Jaeger) instance. You can mount the same volumes if you create a distributed tracing platform (Jaeger) instance with the same name and namespace.
3.2.6.5.2. Connecting to an existing Elasticsearch instance
You can use an existing Elasticsearch cluster for storage with distributed tracing platform. An existing Elasticsearch cluster, also known as an external Elasticsearch instance, is an instance that was not installed by the Red Hat OpenShift distributed tracing platform (Jaeger) Operator or by the Red Hat Elasticsearch Operator.
When you deploy a Jaeger custom resource, the Red Hat OpenShift distributed tracing platform (Jaeger) Operator will not provision Elasticsearch if the following configurations are set:
- 
									spec.storage.elasticsearch.doNotProvisionset totrue
- 
									spec.storage.options.es.server-urlshas a value
- 
									spec.storage.elasticsearch.namehas a value, or if the Elasticsearch instance name iselasticsearch.
							The Red Hat OpenShift distributed tracing platform (Jaeger) Operator uses the Elasticsearch instance specified in spec.storage.elasticsearch.name to connect to Elasticsearch.
						
Restrictions
- You cannot share or reuse a OpenShift Container Platform logging Elasticsearch instance with distributed tracing platform (Jaeger). The Elasticsearch cluster is meant to be dedicated for a single distributed tracing platform (Jaeger) instance.
Red Hat does not provide support for your external Elasticsearch instance. You can review the tested integrations matrix on the Customer Portal.
							The following configuration parameters are for an already existing Elasticsearch instance, also known as an external Elasticsearch instance. In this case, you specify configuration options for Elasticsearch under spec:storage:options:es in your custom resource file.
						
| Parameter | Description | Values | Default value | 
|---|---|---|---|
| es: server-urls:  | URL of the Elasticsearch instance. | The fully-qualified domain name of the Elasticsearch server. | |
| es: max-doc-count:  | 
											The maximum document count to return from an Elasticsearch query. This will also apply to aggregations. If you set both  | 10000 | |
| es: max-num-spans:  | 
											[Deprecated - Will be removed in a future release, use  | 10000 | |
| es: max-span-age:  | The maximum lookback for spans in Elasticsearch. | 72h0m0s | |
| es: sniffer:  | The sniffer configuration for Elasticsearch. The client uses the sniffing process to find all nodes automatically. Disabled by default. | 
											 | 
											 | 
| es: sniffer-tls-enabled:  | Option to enable TLS when sniffing an Elasticsearch Cluster. The client uses the sniffing process to find all nodes automatically. Disabled by default | 
											 | 
											 | 
| es: timeout:  | Timeout used for queries. When set to zero there is no timeout. | 0s | |
| es: username:  | 
											The username required by Elasticsearch. The basic authentication also loads CA if it is specified. See also  | ||
| es: password:  | 
											The password required by Elasticsearch. See also,  | ||
| es: version:  | The major Elasticsearch version. If not specified, the value will be auto-detected from Elasticsearch. | 0 | 
| Parameter | Description | Values | Default value | 
|---|---|---|---|
| es: num-replicas:  | The number of replicas per index in Elasticsearch. | 1 | |
| es: num-shards:  | The number of shards per index in Elasticsearch. | 5 | 
| Parameter | Description | Values | Default value | 
|---|---|---|---|
| es: create-index-templates:  | 
											Automatically create index templates at application startup when set to  | 
											 | 
											 | 
| es: index-prefix:  | Optional prefix for distributed tracing platform (Jaeger) indices. For example, setting this to "production" creates indices named "production-tracing-*". | 
| Parameter | Description | Values | Default value | 
|---|---|---|---|
| es:
  bulk:
    actions: | The number of requests that can be added to the queue before the bulk processor decides to commit updates to disk. | 1000 | |
| es:
  bulk:
    flush-interval: | 
											A  | 200ms | |
| es:
  bulk:
    size: | The number of bytes that the bulk requests can take up before the bulk processor decides to commit updates to disk. | 5000000 | |
| es:
  bulk:
    workers: | The number of workers that are able to receive and commit bulk requests to Elasticsearch. | 1 | 
| Parameter | Description | Values | Default value | 
|---|---|---|---|
| es:
  tls:
    ca: | Path to a TLS Certification Authority (CA) file used to verify the remote servers. | Will use the system truststore by default. | |
| es:
  tls:
    cert: | Path to a TLS Certificate file, used to identify this process to the remote servers. | ||
| es:
  tls:
    enabled: | Enable transport layer security (TLS) when talking to the remote servers. Disabled by default. | 
											 | 
											 | 
| es:
  tls:
    key: | Path to a TLS Private Key file, used to identify this process to the remote servers. | ||
| es:
  tls:
    server-name: | Override the expected TLS server name in the certificate of the remote servers. | ||
| es: token-file:  | Path to a file containing the bearer token. This flag also loads the Certification Authority (CA) file if it is specified. | 
| Parameter | Description | Values | Default value | 
|---|---|---|---|
| es-archive:
  bulk:
    actions: | The number of requests that can be added to the queue before the bulk processor decides to commit updates to disk. | 0 | |
| es-archive:
  bulk:
    flush-interval: | 
											A  | 0s | |
| es-archive:
  bulk:
    size: | The number of bytes that the bulk requests can take up before the bulk processor decides to commit updates to disk. | 0 | |
| es-archive:
  bulk:
    workers: | The number of workers that are able to receive and commit bulk requests to Elasticsearch. | 0 | |
| es-archive: create-index-templates:  | 
											Automatically create index templates at application startup when set to  | 
											 | 
											 | 
| es-archive: enabled:  | Enable extra storage. | 
											 | 
											 | 
| es-archive: index-prefix:  | Optional prefix for distributed tracing platform (Jaeger) indices. For example, setting this to "production" creates indices named "production-tracing-*". | ||
| es-archive: max-doc-count:  | The maximum document count to return from an Elasticsearch query. This will also apply to aggregations. | 0 | |
| es-archive: max-num-spans:  | 
											[Deprecated - Will be removed in a future release, use  | 0 | |
| es-archive: max-span-age:  | The maximum lookback for spans in Elasticsearch. | 0s | |
| es-archive: num-replicas:  | The number of replicas per index in Elasticsearch. | 0 | |
| es-archive: num-shards:  | The number of shards per index in Elasticsearch. | 0 | |
| es-archive: password:  | 
											The password required by Elasticsearch. See also,  | ||
| es-archive: server-urls:  | 
											The comma-separated list of Elasticsearch servers. Must be specified as fully qualified URLs, for example,  | ||
| es-archive: sniffer:  | The sniffer configuration for Elasticsearch. The client uses the sniffing process to find all nodes automatically. Disabled by default. | 
											 | 
											 | 
| es-archive: sniffer-tls-enabled:  | Option to enable TLS when sniffing an Elasticsearch Cluster. The client uses the sniffing process to find all nodes automatically. Disabled by default. | 
											 | 
											 | 
| es-archive: timeout:  | Timeout used for queries. When set to zero there is no timeout. | 0s | |
| es-archive:
  tls:
    ca: | Path to a TLS Certification Authority (CA) file used to verify the remote servers. | Will use the system truststore by default. | |
| es-archive:
  tls:
    cert: | Path to a TLS Certificate file, used to identify this process to the remote servers. | ||
| es-archive:
  tls:
    enabled: | Enable transport layer security (TLS) when talking to the remote servers. Disabled by default. | 
											 | 
											 | 
| es-archive:
  tls:
    key: | Path to a TLS Private Key file, used to identify this process to the remote servers. | ||
| es-archive:
  tls:
    server-name: | Override the expected TLS server name in the certificate of the remote servers. | ||
| es-archive: token-file:  | Path to a file containing the bearer token. This flag also loads the Certification Authority (CA) file if it is specified. | ||
| es-archive: username:  | 
											The username required by Elasticsearch. The basic authentication also loads CA if it is specified. See also  | ||
| es-archive: version:  | The major Elasticsearch version. If not specified, the value will be auto-detected from Elasticsearch. | 0 | 
Storage example with volume mounts
The following example shows a Jaeger CR using an external Elasticsearch cluster with TLS CA certificate mounted from a volume and user/password stored in a secret.
External Elasticsearch example
- 1
- URL to Elasticsearch service running in default namespace.
- 2
- TLS configuration. In this case only CA certificate, but it can also contain es.tls.key and es.tls.cert when using mutual TLS.
- 3
- Secret which defines environment variables ES_PASSWORD and ES_USERNAME. Created by kubectl create secret generic tracing-secret --from-literal=ES_PASSWORD=changeme --from-literal=ES_USERNAME=elastic
- 4
- Volume mounts and volumes which are mounted into all storage components.
3.2.6.6. Managing certificates with Elasticsearch
You can create and manage certificates using the Red Hat Elasticsearch Operator. Managing certificates using the Red Hat Elasticsearch Operator also lets you use a single Elasticsearch cluster with multiple Jaeger Collectors.
Managing certificates with Elasticsearch is a Technology Preview feature only. Technology Preview features are not supported with Red Hat production service level agreements (SLAs) and might not be functionally complete. Red Hat does not recommend using them in production. These features provide early access to upcoming product features, enabling customers to test functionality and provide feedback during the development process.
For more information about the support scope of Red Hat Technology Preview features, see Technology Preview Features Support Scope.
Starting with version 2.4, the Red Hat OpenShift distributed tracing platform (Jaeger) Operator delegates certificate creation to the Red Hat Elasticsearch Operator by using the following annotations in the Elasticsearch custom resource:
- 
								logging.openshift.io/elasticsearch-cert-management: "true"
- 
								logging.openshift.io/elasticsearch-cert.jaeger-<shared-es-node-name>: "user.jaeger"
- 
								logging.openshift.io/elasticsearch-cert.curator-<shared-es-node-name>: "system.logging.curator"
						Where the <shared-es-node-name> is the name of the Elasticsearch node. For example, if you create an Elasticsearch node named custom-es, your custom resource might look like the following example.
					
Example Elasticsearch CR showing annotations
Prerequisites
- OpenShift Container Platform 4.7
- {logging-title} 5.2
- 
								The Elasticsearch node and the Jaeger instances must be deployed in the same namespace. For example, tracing-system.
						You enable certificate management by setting spec.storage.elasticsearch.useCertManagement to true in the Jaeger custom resource.
					
Example showing useCertManagement
						The Red Hat OpenShift distributed tracing platform (Jaeger) Operator sets the Elasticsearch custom resource name to the value of spec.storage.elasticsearch.name from the Jaeger custom resource when provisioning Elasticsearch.
					
The certificates are provisioned by the Red Hat Elasticsearch Operator and the Red Hat OpenShift distributed tracing platform (Jaeger) Operator injects the certificates.
3.2.6.7. Query configuration options
Query is a service that retrieves traces from storage and hosts the user interface to display them.
| Parameter | Description | Values | Default value | 
|---|---|---|---|
| spec:
  query:
    replicas: | Specifies the number of Query replicas to create. | 
										Integer, for example,  | 
| Parameter | Description | Values | Default value | 
|---|---|---|---|
| spec:
  query:
    options: {} | Configuration options that define the Query service. | ||
| options: log-level:  | Logging level for Query. | 
										Possible values:  | |
| options:
  query:
    base-path: | 
										The base path for all jaeger-query HTTP routes can be set to a non-root value, for example,  | /<path> | 
Sample Query configuration
3.2.6.8. Ingester configuration options
						Ingester is a service that reads from a Kafka topic and writes to the Elasticsearch storage backend. If you are using the allInOne or production deployment strategies, you do not need to configure the Ingester service.
					
| Parameter | Description | Values | 
|---|---|---|
| spec:
  ingester:
    options: {} | Configuration options that define the Ingester service. | |
| options: deadlockInterval:  | 
										Specifies the interval, in seconds or minutes, that the Ingester must wait for a message before terminating. The deadlock interval is disabled by default (set to  | 
										Minutes and seconds, for example,  | 
| options:
  kafka:
    consumer:
      topic: | 
										The  | 
										Label for the consumer. For example,  | 
| options:
  kafka:
    consumer:
      brokers: | Identifies the Kafka configuration used by the Ingester to consume the messages. | 
										Label for the broker, for example,  | 
| options: log-level:  | Logging level for the Ingester. | 
										Possible values:  | 
Streaming Collector and Ingester example
3.2.7. Injecting sidecars
The Red Hat OpenShift distributed tracing platform (Jaeger) relies on a proxy sidecar within the application’s pod to provide the Agent. The Red Hat OpenShift distributed tracing platform (Jaeger) Operator can inject Agent sidecars into deployment workloads. You can enable automatic sidecar injection or manage it manually.
3.2.7.1. Automatically injecting sidecars
						The Red Hat OpenShift distributed tracing platform (Jaeger) Operator can inject Jaeger Agent sidecars into deployment workloads. To enable automatic injection of sidecars, add the sidecar.jaegertracing.io/inject annotation set to either the string true or to the distributed tracing platform (Jaeger) instance name that is returned by running $ oc get jaegers. When you specify true, there must be only a single distributed tracing platform (Jaeger) instance for the same namespace as the deployment. Otherwise, the Operator is unable to determine which distributed tracing platform (Jaeger) instance to use. A specific distributed tracing platform (Jaeger) instance name on a deployment has a higher precedence than true applied on its namespace.
					
The following snippet shows a simple application that will inject a sidecar, with the agent pointing to the single distributed tracing platform (Jaeger) instance available in the same namespace:
Automatic sidecar injection example
- 1
- Set to either the stringtrueor to the Jaeger instance name.
						When the sidecar is injected, the agent can then be accessed at its default location on localhost.
					
3.2.7.2. Manually injecting sidecars
						The Red Hat OpenShift distributed tracing platform (Jaeger) Operator can only automatically inject Jaeger Agent sidecars into Deployment workloads. For controller types other than Deployments, such as StatefulSets`and `DaemonSets, you can manually define the Jaeger agent sidecar in your specification.
					
The following snippet shows the manual definition you can include in your containers section for a Jaeger agent sidecar:
Sidecar definition example for a StatefulSet
The agent can then be accessed at its default location on localhost.
3.3. Updating the distributed tracing platform Jaeger
Jaeger is deprecated in Red Hat OpenShift distributed tracing 3.0.
Operator Lifecycle Manager (OLM) controls the installation, upgrade, and role-based access control (RBAC) of Operators in a cluster. The OLM runs by default in OpenShift Container Platform. OLM queries for available Operators as well as upgrades for installed Operators.
During an update, the Red Hat OpenShift distributed tracing platform Operators upgrade the managed distributed tracing platform instances to the version associated with the Operator. Whenever a new version of the Red Hat OpenShift distributed tracing platform (Jaeger) Operator is installed, all the distributed tracing platform (Jaeger) application instances managed by the Operator are upgraded to the Operator’s version. For example, after upgrading the Operator from 1.10 installed to 1.11, the Operator scans for running distributed tracing platform (Jaeger) instances and upgrades them to 1.11 as well.
If you have not already updated your OpenShift Elasticsearch Operator as described in Updating OpenShift Logging, complete that update before updating your Red Hat OpenShift distributed tracing platform (Jaeger) Operator.
3.4. Removing the distributed tracing platform Jaeger
The steps for removing Red Hat OpenShift distributed tracing platform from an OpenShift Container Platform cluster are as follows:
- Shut down any Red Hat OpenShift distributed tracing platform pods.
- Remove any Red Hat OpenShift distributed tracing platform instances.
- Remove the Red Hat OpenShift distributed tracing platform (Jaeger) Operator.
- Remove the Red Hat build of OpenTelemetry Operator.
3.4.1. Removing a distributed tracing platform (Jaeger) instance by using the web console
You can remove a distributed tracing platform (Jaeger) instance in the Administrator view of the web console.
When deleting an instance that uses in-memory storage, all data is irretrievably lost. Data stored in persistent storage such as Elasticsearch is not deleted when a Red Hat OpenShift distributed tracing platform (Jaeger) instance is removed.
Prerequisites
- 
							You are logged in to the web console as a cluster administrator with the cluster-adminrole.
Procedure
- Log in to the OpenShift Container Platform web console.
- 
							Navigate to Operators Installed Operators. 
- 
							Select the name of the project where the Operators are installed from the Project menu, for example, openshift-operators.
- Click the Red Hat OpenShift distributed tracing platform (Jaeger) Operator.
- Click the Jaeger tab.
- 
							Click the Options menu 
							 next to the instance you want to delete and select Delete Jaeger. next to the instance you want to delete and select Delete Jaeger.
- In the confirmation message, click Delete.
3.4.2. Removing a distributed tracing platform (Jaeger) instance by using the CLI
You can remove a distributed tracing platform (Jaeger) instance on the command line.
Prerequisites
- An active OpenShift CLI ( - oc) session by a cluster administrator with the- cluster-adminrole.Tip- 
									Ensure that your OpenShift CLI (oc) version is up to date and matches your OpenShift Container Platform version.
- Run - oc login:- oc login --username=<your_username> - $ oc login --username=<your_username>- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
 
- 
									Ensure that your OpenShift CLI (
Procedure
- Log in with the OpenShift CLI ( - oc) by running the following command:- oc login --username=<NAMEOFUSER> - $ oc login --username=<NAMEOFUSER>- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- To display the distributed tracing platform (Jaeger) instances, run the following command: - oc get deployments -n <jaeger-project> - $ oc get deployments -n <jaeger-project>- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - For example, - oc get deployments -n openshift-operators - $ oc get deployments -n openshift-operators- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - The names of Operators have the suffix - -operator. The following example shows two Red Hat OpenShift distributed tracing platform (Jaeger) Operators and four distributed tracing platform (Jaeger) instances:- oc get deployments -n openshift-operators - $ oc get deployments -n openshift-operators- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - You will see output similar to the following: - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- To remove an instance of distributed tracing platform (Jaeger), run the following command: - oc delete jaeger <deployment-name> -n <jaeger-project> - $ oc delete jaeger <deployment-name> -n <jaeger-project>- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - For example: - oc delete jaeger tracing2 -n openshift-operators - $ oc delete jaeger tracing2 -n openshift-operators- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- To verify the deletion, run the - oc get deploymentscommand again:- oc get deployments -n <jaeger-project> - $ oc get deployments -n <jaeger-project>- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - For example: - oc get deployments -n openshift-operators - $ oc get deployments -n openshift-operators- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - You will see generated output that is similar to the following example: - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
3.4.3. Removing the Red Hat OpenShift distributed tracing platform Operators
Procedure
- Follow the instructions in Deleting Operators from a cluster to remove the Red Hat OpenShift distributed tracing platform (Jaeger) Operator.
- Optional: After the Red Hat OpenShift distributed tracing platform (Jaeger) Operator has been removed, remove the OpenShift Elasticsearch Operator.