Questo contenuto non è disponibile nella lingua selezionata.
Distributed Tracing
Configuring and using distributed tracing in OpenShift Container Platform
Abstract
Chapter 1. Release notes for the Red Hat OpenShift Distributed Tracing Platform 3.7 Copia collegamentoCollegamento copiato negli appunti!
1.1. About this release Copia collegamentoCollegamento copiato negli appunti!
Distributed Tracing Platform 3.7 is provided through the Tempo Operator 0.18.0 and based on the open source Grafana Tempo 2.8.2.
Some linked Jira tickets are accessible only with Red Hat credentials.
Only supported features are documented. Undocumented features are currently unsupported. If you need assistance with a feature, contact Red Hat’s support.
1.2. New features and enhancements Copia collegamentoCollegamento copiato negli appunti!
- Network policy to restrict API access
- With this update, the Tempo Operator creates a network policy for the Operator to restrict access to the used APIs.
1.3. Known issues Copia collegamentoCollegamento copiato negli appunti!
- Tempo query frontend fails to fetch trace JSON
In the Jaeger UI, clicking on Trace and refreshing the page, or accessing Trace → Trace Timeline → Trace JSON from the Tempo query frontend, might result in the Tempo query pod failing with an EOF error.
To work around this problem, use the distributed tracing UI plugin to view traces.
1.4. Fixed issues Copia collegamentoCollegamento copiato negli appunti!
This release fixes the following CVE:
1.5. Getting support Copia collegamentoCollegamento copiato negli appunti!
If you experience difficulty with a procedure described in this documentation, or with OpenShift Container Platform in general, visit the Red Hat Customer Portal. From the Customer Portal, you can:
- Search or browse through the Red Hat Knowledgebase of articles and solutions relating to Red Hat products.
- Submit a support case to Red Hat Support.
- Access other product documentation.
To identify issues with your cluster, you can use Insights in OpenShift Cluster Manager Hybrid Cloud Console. Insights provides details about issues and, if available, information on how to solve a problem.
If you have a suggestion for improving this documentation or have found an error, submit a Jira issue for the most relevant documentation component. Please provide specific details, such as the section name and OpenShift Container Platform version.
Chapter 2. About the Distributed Tracing Platform Copia collegamentoCollegamento copiato negli appunti!
2.1. Key concepts in distributed tracing Copia collegamentoCollegamento copiato negli appunti!
Every time a user takes an action in an application, a request is executed by the architecture that may require dozens of different services to participate to produce a response. Red Hat OpenShift Distributed Tracing Platform lets you perform distributed tracing, which records the path of a request through various microservices that make up an application.
Distributed tracing is a technique that is used to tie the information about different units of work together — usually executed in different processes or hosts — to understand a whole chain of events in a distributed transaction. Developers can visualize call flows in large microservice architectures with distributed tracing. It is valuable for understanding serialization, parallelism, and sources of latency.
Red Hat OpenShift Distributed Tracing Platform records the execution of individual requests across the whole stack of microservices, and presents them as traces. A trace is a data/execution path through the system. An end-to-end trace consists of one or more spans.
A span represents a logical unit of work in Red Hat OpenShift Distributed Tracing Platform that has an operation name, the start time of the operation, and the duration, as well as potentially tags and logs. Spans may be nested and ordered to model causal relationships.
As a service owner, you can use distributed tracing to instrument your services to gather insights into your service architecture. You can use Red Hat OpenShift Distributed Tracing Platform for monitoring, network profiling, and troubleshooting the interaction between components in modern, cloud-native, microservices-based applications.
With Distributed Tracing Platform, you can perform the following functions:
- Monitor distributed transactions
- Optimize performance and latency
- Perform root cause analysis
You can combine Distributed Tracing Platform with other relevant components of the OpenShift Container Platform:
- Red Hat build of OpenTelemetry for forwarding traces to a TempoStack instance
- Distributed tracing UI plugin of the Cluster Observability Operator (COO)
2.2. Red Hat OpenShift Distributed Tracing Platform features Copia collegamentoCollegamento copiato negli appunti!
Red Hat OpenShift Distributed Tracing Platform provides the following capabilities:
- Integration with Kiali – When properly configured, you can view Distributed Tracing Platform data from the Kiali console.
- High scalability – The Distributed Tracing Platform back end is designed to have no single points of failure and to scale with the business needs.
- Distributed Context Propagation – Enables you to connect data from different components together to create a complete end-to-end trace.
- Backwards compatibility with Zipkin – Red Hat OpenShift Distributed Tracing Platform has APIs that enable it to be used as a drop-in replacement for Zipkin, but Red Hat is not supporting Zipkin compatibility in this release.
2.3. Red Hat OpenShift Distributed Tracing Platform architecture Copia collegamentoCollegamento copiato negli appunti!
Red Hat OpenShift Distributed Tracing Platform is made up of several components that work together to collect, store, and display tracing data.
Red Hat OpenShift Distributed Tracing Platform - This component is based on the open source Grafana Tempo project.
- Gateway – The Gateway handles authentication, authorization, and forwarding requests to the Distributor or Query front-end service.
-
Distributor – The Distributor accepts spans in multiple formats including Jaeger, OpenTelemetry, and Zipkin. It routes spans to Ingesters by hashing the
traceID
and using a distributed consistent hash ring. - Ingester – The Ingester batches a trace into blocks, creates bloom filters and indexes, and then flushes it all to the back end.
- Query Frontend – The Query Frontend is responsible for sharding the search space for an incoming query. The search query is then sent to the Queriers. The Query Frontend deployment exposes the Jaeger UI through the Tempo Query sidecar.
- Querier - The Querier is responsible for finding the requested trace ID in either the Ingesters or the back-end storage. Depending on parameters, it can query the Ingesters and pull Bloom indexes from the back end to search blocks in object storage.
- Compactor – The Compactors stream blocks to and from the back-end storage to reduce the total number of blocks.
Red Hat build of OpenTelemetry - This component is based on the open source OpenTelemetry project.
- OpenTelemetry Collector - The OpenTelemetry Collector is a vendor-agnostic way to receive, process, and export telemetry data. The OpenTelemetry Collector supports open-source observability data formats, for example, Jaeger and Prometheus, sending to one or more open-source or commercial back-ends. The Collector is the default location instrumentation libraries export their telemetry data.
Red Hat OpenShift Distributed Tracing Platform (Jaeger) - This component is based on the open source Jaeger project.
ImportantThe Red Hat OpenShift Distributed Tracing Platform (Jaeger) is a deprecated feature. Deprecated functionality is still included in OpenShift Container Platform and continues to be supported; however, it will be removed in a future release of this product and is not recommended for new deployments.
The Red Hat OpenShift Distributed Tracing Platform Operator (Jaeger) will be removed from the
redhat-operators
catalog in a future release. For more information, see the Red Hat Knowledgebase solution Jaeger Deprecation and Removal in OpenShift.Users must migrate to the Tempo Operator and the Red Hat build of OpenTelemetry for distributed tracing collection and storage.
For the most recent list of major functionality that has been deprecated or removed within OpenShift Container Platform, refer to the Deprecated and removed features section of the OpenShift Container Platform release notes.
- Client (Jaeger client, Tracer, Reporter, instrumented application, client libraries)- The Distributed Tracing Platform (Jaeger) clients are language-specific implementations of the OpenTracing API. They might be used to instrument applications for distributed tracing either manually or with a variety of existing open source frameworks, such as Camel (Fuse), Spring Boot (RHOAR), MicroProfile (RHOAR/Thorntail), Wildfly (EAP), and many more, that are already integrated with OpenTracing.
- Agent (Jaeger agent, Server Queue, Processor Workers) - The Distributed Tracing Platform (Jaeger) agent is a network daemon that listens for spans sent over User Datagram Protocol (UDP), which it batches and sends to the Collector. The agent is meant to be placed on the same host as the instrumented application. This is typically accomplished by having a sidecar in container environments such as Kubernetes.
- Jaeger Collector (Collector, Queue, Workers) - Similar to the Jaeger agent, the Jaeger Collector receives spans and places them in an internal queue for processing. This allows the Jaeger Collector to return immediately to the client/agent instead of waiting for the span to make its way to the storage.
- Storage (Data Store) - Collectors require a persistent storage backend. Red Hat OpenShift Distributed Tracing Platform (Jaeger) has a pluggable mechanism for span storage. Red Hat OpenShift Distributed Tracing Platform (Jaeger) supports the Elasticsearch storage.
- Query (Query Service) - Query is a service that retrieves traces from storage.
- Ingester (Ingester Service) - Red Hat OpenShift Distributed Tracing Platform can use Apache Kafka as a buffer between the Collector and the actual Elasticsearch backing storage. Ingester is a service that reads data from Kafka and writes to the Elasticsearch storage backend.
- Jaeger Console – With the Red Hat OpenShift Distributed Tracing Platform (Jaeger) user interface, you can visualize your distributed tracing data. On the Search page, you can find traces and explore details of the spans that make up an individual trace.
Chapter 3. Installing the Distributed Tracing Platform Copia collegamentoCollegamento copiato negli appunti!
For information about installing the deprecated Distributed Tracing Platform (Jaeger), see Installing in the Distributed Tracing Platform (Jaeger) documentation.
Installing the Distributed Tracing Platform involves the following steps:
- Installing the Tempo Operator.
- Setting up a supported object store and creating a secret for the object store credentials.
- Configuring the permissions and tenants.
Depending on your use case, installing your choice of deployment:
-
Microservices-mode
TempoStack
instance -
Monolithic-mode
TempoMonolithic
instance
-
Microservices-mode
3.1. Installing the Tempo Operator Copia collegamentoCollegamento copiato negli appunti!
You can install the Tempo Operator by using the web console or the command line.
3.1.1. Installing the Tempo Operator by using the web console Copia collegamentoCollegamento copiato negli appunti!
You can install the Tempo Operator from the Administrator view of the web console.
Prerequisites
-
You are logged in to the OpenShift Container Platform web console as a cluster administrator with the
cluster-admin
role. -
For Red Hat OpenShift Dedicated, you must be logged in using an account with the
dedicated-admin
role. You have completed setting up the required object storage by a supported provider: Red Hat OpenShift Data Foundation, MinIO, Amazon S3, Azure Blob Storage, Google Cloud Storage. For more information, see "Object storage setup".
WarningObject storage is required and not included with the Distributed Tracing Platform. You must choose and set up object storage by a supported provider before installing the Distributed Tracing Platform.
Procedure
-
Go to Operators → OperatorHub and search for
Tempo Operator
. Select the Tempo Operator that is provided by Red Hat.
ImportantThe following selections are the default presets for this Operator:
- Update channel → stable
- Installation mode → All namespaces on the cluster
- Installed Namespace → openshift-tempo-operator
- Update approval → Automatic
- Select the Enable Operator recommended cluster monitoring on this Namespace checkbox.
- Select Install → Install → View Operator.
Verification
- In the Details tab of the page of the installed Operator, under ClusterServiceVersion details, verify that the installation Status is Succeeded.
3.1.2. Installing the Tempo Operator by using the CLI Copia collegamentoCollegamento copiato negli appunti!
You can install the Tempo Operator from the command line.
Prerequisites
An active OpenShift CLI (
oc
) session by a cluster administrator with thecluster-admin
role.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 (
You have completed setting up the required object storage by a supported provider: Red Hat OpenShift Data Foundation, MinIO, Amazon S3, Azure Blob Storage, Google Cloud Storage. For more information, see "Object storage setup".
WarningObject storage is required and not included with the Distributed Tracing Platform. You must choose and set up object storage by a supported provider before installing the Distributed Tracing Platform.
Procedure
Create a project for the Tempo Operator by running the following command:
Copy to Clipboard Copied! Toggle word wrap Toggle overflow Create an Operator group by running the following command:
Copy to Clipboard Copied! Toggle word wrap Toggle overflow Create a subscription by running the following command:
Copy to Clipboard Copied! Toggle word wrap Toggle overflow
Verification
Check the Operator status by running the following command:
oc get csv -n openshift-tempo-operator
$ oc get csv -n openshift-tempo-operator
Copy to Clipboard Copied! Toggle word wrap Toggle overflow
3.2. Object storage setup Copia collegamentoCollegamento copiato negli appunti!
You can use the following configuration parameters when setting up a supported object storage.
Using object storage requires setting up a supported object store and creating a secret for the object store credentials before deploying a TempoStack
or TempoMonolithic
instance.
Storage provider | Secret parameters |
---|---|
| |
MinIO | See MinIO Operator.
|
Amazon S3 |
|
Amazon S3 with Security Token Service (STS) |
|
Microsoft Azure Blob Storage |
|
Google Cloud Storage on Google Cloud Platform (GCP) |
|
3.2.1. Setting up the Amazon S3 storage with the Security Token Service Copia collegamentoCollegamento copiato negli appunti!
You can set up the Amazon S3 storage with the Security Token Service (STS) and AWS Command Line Interface (AWS CLI). Optionally, you can also use the Cloud Credential Operator (CCO).
Using the Distributed Tracing Platform with the Amazon S3 storage and STS 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.
Prerequisites
- You have installed the latest version of the AWS CLI.
- If you intend to use the CCO, you have installed and configured the CCO in your cluster.
Procedure
- Create an AWS S3 bucket.
Create the following
trust.json
file for the AWS Identity and Access Management (AWS IAM) policy for the purpose of setting up a trust relationship between the AWS IAM role, which you will create in the next step, and the service account of either theTempoStack
orTempoMonolithic
instance:trust.json
Copy to Clipboard Copied! Toggle word wrap Toggle overflow - 1
- The OpenID Connect (OIDC) provider that you have configured on the OpenShift Container Platform.
- 2
- The namespace in which you intend to create either a
TempoStack
orTempoMonolithic
instance. Replace<tempo_custom_resource_name>
with themetadata
name that you define in yourTempoStack
orTempoMonolithic
custom resource.
TipYou can also get the value for the OIDC provider by running the following command:
oc get authentication cluster -o json | jq -r '.spec.serviceAccountIssuer' | sed 's~http[s]*://~~g'
$ oc get authentication cluster -o json | jq -r '.spec.serviceAccountIssuer' | sed 's~http[s]*://~~g'
Copy to Clipboard Copied! Toggle word wrap Toggle overflow Create an AWS IAM role by attaching the created
trust.json
policy file. You can do this by running the following command:aws iam create-role \ --role-name "tempo-s3-access" \ --assume-role-policy-document "file:///tmp/trust.json" \ --query Role.Arn \ --output text
$ aws iam create-role \ --role-name "tempo-s3-access" \ --assume-role-policy-document "file:///tmp/trust.json" \ --query Role.Arn \ --output text
Copy to Clipboard Copied! Toggle word wrap Toggle overflow Attach an AWS IAM policy to the created AWS IAM role. You can do this by running the following command:
aws iam attach-role-policy \ --role-name "tempo-s3-access" \ --policy-arn "arn:aws:iam::aws:policy/AmazonS3FullAccess"
$ aws iam attach-role-policy \ --role-name "tempo-s3-access" \ --policy-arn "arn:aws:iam::aws:policy/AmazonS3FullAccess"
Copy to Clipboard Copied! Toggle word wrap Toggle overflow If you are not using the CCO, skip this step. If you are using the CCO, configure the cloud provider environment for the Tempo Operator. You can do this by running the following command:
oc patch subscription <tempo_operator_sub> \ -n <tempo_operator_namespace> \ --type='merge' -p '{"spec": {"config": {"env": [{"name": "ROLEARN", "value": "'"<role_arn>"'"}]}}}'
$ oc patch subscription <tempo_operator_sub> \
1 -n <tempo_operator_namespace> \
2 --type='merge' -p '{"spec": {"config": {"env": [{"name": "ROLEARN", "value": "'"<role_arn>"'"}]}}}'
3 Copy to Clipboard Copied! Toggle word wrap Toggle overflow In the OpenShift Container Platform, create an object storage secret with keys as follows:
Copy to Clipboard Copied! Toggle word wrap Toggle overflow When the object storage secret is created, update the relevant custom resource of the Distributed Tracing Platform instance as follows:
Example
TempoStack
custom resourceCopy to Clipboard Copied! Toggle word wrap Toggle overflow Example
TempoMonolithic
custom resourceCopy to Clipboard Copied! Toggle word wrap Toggle overflow
3.2.2. Setting up the Azure storage with the Security Token Service Copia collegamentoCollegamento copiato negli appunti!
You can set up the Azure storage with the Security Token Service (STS) by using the Azure Command Line Interface (Azure CLI).
Using the Distributed Tracing Platform with the Azure storage and STS 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.
Prerequisites
- You have installed the latest version of the Azure CLI.
- You have created an Azure storage account.
- You have created an Azure blob storage container.
Procedure
Create an Azure managed identity by running the following command:
az identity create \ --name <identity_name> \ --resource-group <resource_group> \ --location <region> \ --subscription <subscription_id>
$ az identity create \ --name <identity_name> \
1 --resource-group <resource_group> \
2 --location <region> \
3 --subscription <subscription_id>
4 Copy to Clipboard Copied! Toggle word wrap Toggle overflow Create a federated identity credential for the OpenShift Container Platform service account for use by all components of the Distributed Tracing Platform except the Query Frontend. You can do this by running the following command:
Copy to Clipboard Copied! Toggle word wrap Toggle overflow - 1
- Federated identity credentials allow OpenShift Container Platform service accounts to authenticate as an Azure managed identity without storing secrets or using an Azure service principal identity.
- 2
- The name you have chosen for the federated credential.
- 3
- The URL of the OpenID Connect (OIDC) provider for your cluster.
- 4
- The service account subject for your cluster in the following format:
system:serviceaccount:<namespace>:tempo-<tempostack_instance_name>
. - 5
- The expected audience, which is to be used for validating the issued tokens for the federated identity credential. This is commonly set to
api://AzureADTokenExchange
.
TipYou can get the URL of the OpenID Connect (OIDC) issuer for your cluster by running the following command:
oc get authentication cluster -o json | jq -r .spec.serviceAccountIssuer
$ oc get authentication cluster -o json | jq -r .spec.serviceAccountIssuer
Copy to Clipboard Copied! Toggle word wrap Toggle overflow Create a federated identity credential for the OpenShift Container Platform service account for use by the Query Frontend component of the Distributed Tracing Platform. You can do this by running the following command:
Copy to Clipboard Copied! Toggle word wrap Toggle overflow - 1
- Federated identity credentials allow OpenShift Container Platform service accounts to authenticate as an Azure managed identity without storing secrets or using an Azure service principal identity.
- 2
- The name you have chosen for the frontend federated identity credential.
- 3
- The service account subject for your cluster in the following format:
system:serviceaccount:<namespace>:tempo-<tempostack_instance_name>
.
Assign the Storage Blob Data Contributor role to the Azure service principal identity of the created Azure managed identity. You can do this by running the following command:
az role assignment create \ --assignee <assignee_name> \ --role "Storage Blob Data Contributor" \ --scope "/subscriptions/<subscription_id>
$ az role assignment create \ --assignee <assignee_name> \
1 --role "Storage Blob Data Contributor" \ --scope "/subscriptions/<subscription_id>
Copy to Clipboard Copied! Toggle word wrap Toggle overflow - 1
- The Azure service principal identity of the Azure managed identity that you created in step 1.
TipYou can get the
<assignee_name>
value by running the following command:az ad sp list --all --filter "servicePrincipalType eq 'ManagedIdentity'" | jq -r --arg idName <identity_name> '.[] | select(.displayName == $idName) | .appId'`
$ az ad sp list --all --filter "servicePrincipalType eq 'ManagedIdentity'" | jq -r --arg idName <identity_name> '.[] | select(.displayName == $idName) | .appId'`
Copy to Clipboard Copied! Toggle word wrap Toggle overflow Fetch the client ID of the Azure managed identity that you created in step 1:
CLIENT_ID=$(az identity show \ --name <identity_name> \ --resource-group <resource_group> \ --query clientId \ -o tsv)
CLIENT_ID=$(az identity show \ --name <identity_name> \
1 --resource-group <resource_group> \
2 --query clientId \ -o tsv)
Copy to Clipboard Copied! Toggle word wrap Toggle overflow Create an OpenShift Container Platform secret for the Azure workload identity federation (WIF). You can do this by running the following command:
Copy to Clipboard Copied! Toggle word wrap Toggle overflow When the object storage secret is created, update the relevant custom resource of the Distributed Tracing Platform instance as follows:
Example
TempoStack
custom resourceCopy to Clipboard Copied! Toggle word wrap Toggle overflow - 1
- The secret that you created in the previous step.
Example
TempoMonolithic
custom resourceCopy to Clipboard Copied! Toggle word wrap Toggle overflow - 1
- The secret that you created in the previous step.
3.2.3. Setting up the Google Cloud storage with the Security Token Service Copia collegamentoCollegamento copiato negli appunti!
You can set up the Google Cloud Storage (GCS) with the Security Token Service (STS) by using the Google Cloud CLI.
Using the Distributed Tracing Platform with the GCS and STS 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.
Prerequisites
- You have installed the latest version of the Google Cloud CLI.
Procedure
- Create a GCS bucket on the Google Cloud Platform (GCP).
Create or reuse a service account with Google’s Identity and Access Management (IAM):
SERVICE_ACCOUNT_EMAIL=$(gcloud iam service-accounts create <iam_service_account_name> \ --display-name="Tempo Account" \ --project <project_id> \ --format='value(email)' \ --quiet)
SERVICE_ACCOUNT_EMAIL=$(gcloud iam service-accounts create <iam_service_account_name> \
1 --display-name="Tempo Account" \ --project <project_id> \
2 --format='value(email)' \ --quiet)
Copy to Clipboard Copied! Toggle word wrap Toggle overflow Bind the required GCP roles to the created service account at the project level. You can do this by running the following command:
gcloud projects add-iam-policy-binding <project_id> \ --member "serviceAccount:$SERVICE_ACCOUNT_EMAIL" \ --role "roles/storage.objectAdmin"
$ gcloud projects add-iam-policy-binding <project_id> \ --member "serviceAccount:$SERVICE_ACCOUNT_EMAIL" \ --role "roles/storage.objectAdmin"
Copy to Clipboard Copied! Toggle word wrap Toggle overflow Retrieve the
POOL_ID
value of the Google Cloud Workload Identity Pool that is associated with the cluster. How you can retrieve this value depends on your environment, so the following command is only an example:OIDC_ISSUER=$(oc get authentication.config cluster -o jsonpath='{.spec.serviceAccountIssuer}') \ &&
$ OIDC_ISSUER=$(oc get authentication.config cluster -o jsonpath='{.spec.serviceAccountIssuer}') \ && POOL_ID=$(echo "$OIDC_ISSUER" | awk -F'/' '{print $NF}' | sed 's/-oidc$//')
Copy to Clipboard Copied! Toggle word wrap Toggle overflow Add the IAM policy bindings. You can do this by running the following commands:
Copy to Clipboard Copied! Toggle word wrap Toggle overflow - 1
- The
$SERVICE_ACCOUNT_EMAIL
is the output of the command in step 2.
Create a credential file for the
key.json
key of the storage secret for use by theTempoStack
custom resource. You can do this by running the following command:Copy to Clipboard Copied! Toggle word wrap Toggle overflow Get the correct audience by running the following command:
gcloud iam workload-identity-pools providers describe "$PROVIDER_NAME" --format='value(oidc.allowedAudiences[0])'
$ gcloud iam workload-identity-pools providers describe "$PROVIDER_NAME" --format='value(oidc.allowedAudiences[0])'
Copy to Clipboard Copied! Toggle word wrap Toggle overflow Create a storage secret for the Distributed Tracing Platform by running the following command.
oc -n <tempo_namespace> create secret generic gcs-secret \ --from-literal=bucketname="<bucket_name>" \ --from-literal=audience="<audience>" \ --from-file=key.json=<output_file_path>
$ oc -n <tempo_namespace> create secret generic gcs-secret \ --from-literal=bucketname="<bucket_name>" \
1 --from-literal=audience="<audience>" \
2 --from-file=key.json=<output_file_path>
3 Copy to Clipboard Copied! Toggle word wrap Toggle overflow When the object storage secret is created, update the relevant custom resource of the Distributed Tracing Platform instance as follows:
Example
TempoStack
custom resourceCopy to Clipboard Copied! Toggle word wrap Toggle overflow - 1
- The secret that you created in the previous step.
Example
TempoMonolithic
custom resourceCopy to Clipboard Copied! Toggle word wrap Toggle overflow - 1
- The secret that you created in the previous step.
3.2.4. Setting up IBM Cloud Object Storage Copia collegamentoCollegamento copiato negli appunti!
You can set up IBM Cloud Object Storage by using the OpenShift CLI (oc
).
Prerequisites
-
You have installed the latest version of OpenShift CLI (
oc
). For more information, see "Getting started with the OpenShift CLI" in Configure: CLI tools. -
You have installed the latest version of IBM Cloud Command Line Interface (
ibmcloud
). For more information, see "Getting started with the IBM Cloud CLI" in IBM Cloud Docs. You have configured IBM Cloud Object Storage. For more information, see "Choosing a plan and creating an instance" in IBM Cloud Docs.
- You have an IBM Cloud Platform account.
- You have ordered an IBM Cloud Object Storage plan.
- You have created an instance of IBM Cloud Object Storage.
Procedure
- On IBM Cloud, create an object store bucket.
On IBM Cloud, create a service key for connecting to the object store bucket by running the following command:
ibmcloud resource service-key-create <tempo_bucket> Writer \ --instance-name <tempo_bucket> --parameters '{"HMAC":true}'
$ ibmcloud resource service-key-create <tempo_bucket> Writer \ --instance-name <tempo_bucket> --parameters '{"HMAC":true}'
Copy to Clipboard Copied! Toggle word wrap Toggle overflow On IBM Cloud, create a secret with the bucket credentials by running the following command:
oc -n <namespace> create secret generic <ibm_cos_secret> \ --from-literal=bucket="<tempo_bucket>" \ --from-literal=endpoint="<ibm_bucket_endpoint>" \ --from-literal=access_key_id="<ibm_bucket_access_key>" \ --from-literal=access_key_secret="<ibm_bucket_secret_key>"
$ oc -n <namespace> create secret generic <ibm_cos_secret> \ --from-literal=bucket="<tempo_bucket>" \ --from-literal=endpoint="<ibm_bucket_endpoint>" \ --from-literal=access_key_id="<ibm_bucket_access_key>" \ --from-literal=access_key_secret="<ibm_bucket_secret_key>"
Copy to Clipboard Copied! Toggle word wrap Toggle overflow On OpenShift Container Platform, create an object storage secret with keys as follows:
Copy to Clipboard Copied! Toggle word wrap Toggle overflow On OpenShift Container Platform, set the storage section in the
TempoStack
custom resource as follows:Copy to Clipboard Copied! Toggle word wrap Toggle overflow - 1
- Name of the secret that contains the IBM Cloud Storage access and secret keys.
3.3. Configuring the permissions and tenants Copia collegamentoCollegamento copiato negli appunti!
Before installing a TempoStack
or TempoMonolithic
instance, you must define one or more tenants and configure their read and write access. You can configure such an authorization setup by using a cluster role and cluster role binding for the Kubernetes Role-Based Access Control (RBAC). By default, no users are granted read or write permissions. For more information, see "Configuring the read permissions for tenants" and "Configuring the write permissions for tenants".
The OpenTelemetry Collector of the Red Hat build of OpenTelemetry can send trace data to a TempoStack
or TempoMonolithic
instance by using the service account with RBAC for writing the data.
Component | Tempo Gateway service | OpenShift OAuth | TokenReview API | SubjectAccessReview API |
---|---|---|---|---|
Authentication | X | X | X | |
Authorization | X | X |
3.3.1. Configuring the read permissions for tenants Copia collegamentoCollegamento copiato negli appunti!
You can configure the read permissions for tenants from the Administrator view of the web console or from the command line.
Prerequisites
-
You are logged in to the OpenShift Container Platform web console as a cluster administrator with the
cluster-admin
role. -
For Red Hat OpenShift Dedicated, you must be logged in using an account with the
dedicated-admin
role.
Procedure
Define the tenants by adding the
tenantName
andtenantId
parameters with your values of choice to theTempoStack
custom resource (CR):Tenant example in a
TempoStack
CRCopy to Clipboard Copied! Toggle word wrap Toggle overflow Add the tenants to a cluster role with the read (
get
) permissions to read traces.Example RBAC configuration in a
ClusterRole
resourceCopy to Clipboard Copied! Toggle word wrap Toggle overflow Grant authenticated users the read permissions for trace data by defining a cluster role binding for the cluster role from the previous step.
Example RBAC configuration in a
ClusterRoleBinding
resourceCopy to Clipboard Copied! Toggle word wrap Toggle overflow - 1
- Grants all authenticated users the read permissions for trace data.
3.3.2. Configuring the write permissions for tenants Copia collegamentoCollegamento copiato negli appunti!
You can configure the write permissions for tenants from the Administrator view of the web console or from the command line.
Prerequisites
-
You are logged in to the OpenShift Container Platform web console as a cluster administrator with the
cluster-admin
role. -
For Red Hat OpenShift Dedicated, you must be logged in using an account with the
dedicated-admin
role. - You have installed the OpenTelemetry Collector and configured it to use an authorized service account with permissions. For more information, see "Creating the required RBAC resources automatically" in the Red Hat build of OpenTelemetry documentation.
Procedure
Create a service account for use with OpenTelemetry Collector.
apiVersion: v1 kind: ServiceAccount metadata: name: otel-collector namespace: <project_of_opentelemetry_collector_instance>
apiVersion: v1 kind: ServiceAccount metadata: name: otel-collector namespace: <project_of_opentelemetry_collector_instance>
Copy to Clipboard Copied! Toggle word wrap Toggle overflow Add the tenants to a cluster role with the write (
create
) permissions to write traces.Example RBAC configuration in a
ClusterRole
resourceCopy to Clipboard Copied! Toggle word wrap Toggle overflow Grant the OpenTelemetry Collector the write permissions by defining a cluster role binding to attach the OpenTelemetry Collector service account.
Example RBAC configuration in a
ClusterRoleBinding
resourceCopy to Clipboard Copied! Toggle word wrap Toggle overflow - 1
- The service account that you created in a previous step. The client uses it when exporting trace data.
Configure the
OpenTelemetryCollector
custom resource as follows:-
Add the
bearertokenauth
extension and a valid token to the tracing pipeline service. -
Add the tenant name in the
otlp/otlphttp
exporters as theX-Scope-OrgID
headers. Enable TLS with a valid certificate authority file.
Sample OpenTelemetry CR configuration
Copy to Clipboard Copied! Toggle word wrap Toggle overflow - 1
- Service account configured with write permissions.
- 2
- Bearer Token extension to use service account token.
- 3
- The service account token. The client sends the token to the tracing pipeline service as the bearer token header.
- 4
- Specify either the OTLP gRPC Exporter (
otlp/dev
) or the OTLP HTTP Exporter (otlphttp/dev
). - 5
- Enabled TLS with a valid service CA file.
- 6
- Header with tenant name.
- 7
- Specify either the OTLP gRPC Exporter (
otlp/dev
) or the OTLP HTTP Exporter (otlphttp/dev
). - 8
- The exporter you specified in
exporters
section of the CR.
-
Add the
3.4. Installing a TempoStack instance Copia collegamentoCollegamento copiato negli appunti!
You can install a TempoStack
instance by using the web console or command line.
3.4.1. Installing a TempoStack instance by using the web console Copia collegamentoCollegamento copiato negli appunti!
You can install a TempoStack
instance from the Administrator view of the web console.
Prerequisites
-
You are logged in to the OpenShift Container Platform web console as a cluster administrator with the
cluster-admin
role. -
For Red Hat OpenShift Dedicated, you must be logged in using an account with the
dedicated-admin
role. You have completed setting up the required object storage by a supported provider: Red Hat OpenShift Data Foundation, MinIO, Amazon S3, Azure Blob Storage, Google Cloud Storage. For more information, see "Object storage setup".
WarningObject storage is required and not included with the Distributed Tracing Platform. You must choose and set up object storage by a supported provider before installing the Distributed Tracing Platform.
- You have defined one or more tenants and configured the read and write permissions. For more information, see "Configuring the read permissions for tenants" and "Configuring the write permissions for tenants".
Procedure
-
Go to Home → Projects → Create Project to create a permitted project of your choice for the
TempoStack
instance that you will create in a subsequent step. Project names beginning with theopenshift-
prefix are not permitted. Go to Workloads → Secrets → Create → From YAML to create a secret for your object storage bucket in the project that you created for the
TempoStack
instance. For more information, see "Object storage setup".Example secret for Amazon S3 and MinIO storage
Copy to Clipboard Copied! Toggle word wrap Toggle overflow Create a
TempoStack
instance.NoteYou can create multiple
TempoStack
instances in separate projects on the same cluster.- Go to Operators → Installed Operators.
- Select TempoStack → Create TempoStack → YAML view.
In the YAML view, customize the
TempoStack
custom resource (CR):Example
TempoStack
CR for AWS S3 and MinIO storage and two tenantsCopy to Clipboard Copied! Toggle word wrap Toggle overflow - 1
- This CR creates a
TempoStack
deployment, which is configured to receive Jaeger Thrift over the HTTP and OpenTelemetry Protocol (OTLP). - 2
- The project that you have chosen for the
TempoStack
deployment. Project names beginning with theopenshift-
prefix are not permitted. - 3
- Red Hat supports only the custom resource options that are available in the Red Hat OpenShift Distributed Tracing Platform documentation.
- 4
- Specifies the storage for storing traces.
- 5
- The secret you created in step 2 for the object storage that had been set up as one of the prerequisites.
- 6
- The value of the
name
field in themetadata
section of the secret. For example:minio
. - 7
- The accepted values are
azure
for Azure Blob Storage;gcs
for Google Cloud Storage; ands3
for Amazon S3, MinIO, or Red Hat OpenShift Data Foundation. For example:s3
. - 8
- The size of the persistent volume claim for the Tempo Write-Ahead Logging (WAL). The default is
10Gi
. For example:1Gi
. - 9
- Optional.
- 10
- The value must be
openshift
. - 11
- The list of tenants.
- 12
- The tenant name, which is used as the value for the
X-Scope-OrgId
HTTP header. - 13
- The unique identifier of the tenant. Must be unique throughout the lifecycle of the
TempoStack
deployment. The Distributed Tracing Platform uses this ID to prefix objects in the object storage. You can reuse the value of the UUID ortempoName
field. - 14
- Enables a gateway that performs authentication and authorization.
- 15
- Exposes the Jaeger UI, which visualizes the data, via a route at
http://<gateway_ingress>/api/traces/v1/<tenant_name>/search
.
- Select Create.
Verification
-
Use the Project: dropdown list to select the project of the
TempoStack
instance. -
Go to Operators → Installed Operators to verify that the Status of the
TempoStack
instance is Condition: Ready. -
Go to Workloads → Pods to verify that all the component pods of the
TempoStack
instance are running. Access the Tempo console:
-
Go to Networking → Routes and Ctrl+F to search for
tempo
. In the Location column, open the URL to access the Tempo console.
NoteThe Tempo console initially shows no trace data following the Tempo console installation.
-
Go to Networking → Routes and Ctrl+F to search for
3.4.2. Installing a TempoStack instance by using the CLI Copia collegamentoCollegamento copiato negli appunti!
You can install a TempoStack
instance from the command line.
Prerequisites
An active OpenShift CLI (
oc
) session by a cluster administrator with thecluster-admin
role.Tip-
Ensure that your OpenShift CLI (
oc
) version is up to date and matches your OpenShift Container Platform version. Run the
oc login
command:oc login --username=<your_username>
$ oc login --username=<your_username>
Copy to Clipboard Copied! Toggle word wrap Toggle overflow
-
Ensure that your OpenShift CLI (
You have completed setting up the required object storage by a supported provider: Red Hat OpenShift Data Foundation, MinIO, Amazon S3, Azure Blob Storage, Google Cloud Storage. For more information, see "Object storage setup".
WarningObject storage is required and not included with the Distributed Tracing Platform. You must choose and set up object storage by a supported provider before installing the Distributed Tracing Platform.
- You have defined one or more tenants and configured the read and write permissions. For more information, see "Configuring the read permissions for tenants" and "Configuring the write permissions for tenants".
Procedure
Run the following command to create a permitted project of your choice for the
TempoStack
instance that you will create in a subsequent step:Copy to Clipboard Copied! Toggle word wrap Toggle overflow - 1
- Project names beginning with the
openshift-
prefix are not permitted.
In the project that you created for the
TempoStack
instance, create a secret for your object storage bucket by running the following command:oc apply -f - << EOF <object_storage_secret> EOF
$ oc apply -f - << EOF <object_storage_secret> EOF
Copy to Clipboard Copied! Toggle word wrap Toggle overflow For more information, see "Object storage setup".
Example secret for Amazon S3 and MinIO storage
Copy to Clipboard Copied! Toggle word wrap Toggle overflow Create a
TempoStack
instance in the project that you created for it:NoteYou can create multiple
TempoStack
instances in separate projects on the same cluster.Customize the
TempoStack
custom resource (CR):Example
TempoStack
CR for AWS S3 and MinIO storage and two tenantsCopy to Clipboard Copied! Toggle word wrap Toggle overflow - 1
- This CR creates a
TempoStack
deployment, which is configured to receive Jaeger Thrift over the HTTP and OpenTelemetry Protocol (OTLP). - 2
- The project that you have chosen for the
TempoStack
deployment. Project names beginning with theopenshift-
prefix are not permitted. - 3
- Red Hat supports only the custom resource options that are available in the Red Hat OpenShift Distributed Tracing Platform documentation.
- 4
- Specifies the storage for storing traces.
- 5
- The secret you created in step 2 for the object storage that had been set up as one of the prerequisites.
- 6
- The value of the
name
field in themetadata
section of the secret. For example:minio
. - 7
- The accepted values are
azure
for Azure Blob Storage;gcs
for Google Cloud Storage; ands3
for Amazon S3, MinIO, or Red Hat OpenShift Data Foundation. For example:s3
. - 8
- The size of the persistent volume claim for the Tempo Write-Ahead Logging (WAL). The default is
10Gi
. For example:1Gi
. - 9
- Optional.
- 10
- The value must be
openshift
. - 11
- The list of tenants.
- 12
- The tenant name, which is used as the value for the
X-Scope-OrgId
HTTP header. - 13
- The unique identifier of the tenant. Must be unique throughout the lifecycle of the
TempoStack
deployment. The Distributed Tracing Platform uses this ID to prefix objects in the object storage. You can reuse the value of the UUID ortempoName
field. - 14
- Enables a gateway that performs authentication and authorization.
- 15
- Exposes the Jaeger UI, which visualizes the data, via a route at
http://<gateway_ingress>/api/traces/v1/<tenant_name>/search
.
Apply the customized CR by running the following command:
oc apply -f - << EOF <tempostack_cr> EOF
$ oc apply -f - << EOF <tempostack_cr> EOF
Copy to Clipboard Copied! Toggle word wrap Toggle overflow
Verification
Verify that the
status
of allTempoStack
components
isRunning
and theconditions
aretype: Ready
by running the following command:oc get tempostacks.tempo.grafana.com simplest -o yaml
$ oc get tempostacks.tempo.grafana.com simplest -o yaml
Copy to Clipboard Copied! Toggle word wrap Toggle overflow Verify that all the
TempoStack
component pods are running by running the following command:oc get pods
$ oc get pods
Copy to Clipboard Copied! Toggle word wrap Toggle overflow Access the Tempo console:
Query the route details by running the following command:
oc get route
$ oc get route
Copy to Clipboard Copied! Toggle word wrap Toggle overflow Open
https://<route_from_previous_step>
in a web browser.NoteThe Tempo console initially shows no trace data following the Tempo console installation.
3.5. Installing a TempoMonolithic instance Copia collegamentoCollegamento copiato negli appunti!
The TempoMonolithic
instance 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.
You can install a TempoMonolithic
instance by using the web console or command line.
The TempoMonolithic
custom resource (CR) creates a Tempo deployment in monolithic mode. All components of the Tempo deployment, such as the compactor, distributor, ingester, querier, and query frontend, are contained in a single container.
A TempoMonolithic
instance supports storing traces in in-memory storage, a persistent volume, or object storage.
Tempo deployment in monolithic mode is preferred for a small deployment, demonstration, testing, and as a migration path of the Red Hat OpenShift Distributed Tracing Platform (Jaeger) all-in-one deployment.
The monolithic deployment of Tempo does not scale horizontally. If you require horizontal scaling, use the TempoStack
CR for a Tempo deployment in microservices mode.
3.5.1. Installing a TempoMonolithic instance by using the web console Copia collegamentoCollegamento copiato negli appunti!
The TempoMonolithic
instance 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.
You can install a TempoMonolithic
instance from the Administrator view of the web console.
Prerequisites
-
You are logged in to the OpenShift Container Platform web console as a cluster administrator with the
cluster-admin
role. -
For Red Hat OpenShift Dedicated, you must be logged in using an account with the
dedicated-admin
role. - You have defined one or more tenants and configured the read and write permissions. For more information, see "Configuring the read permissions for tenants" and "Configuring the write permissions for tenants".
Procedure
-
Go to Home → Projects → Create Project to create a permitted project of your choice for the
TempoMonolithic
instance that you will create in a subsequent step. Project names beginning with theopenshift-
prefix are not permitted. Decide which type of supported storage to use for storing traces: in-memory storage, a persistent volume, or object storage.
ImportantObject storage is not included with the Distributed Tracing Platform and requires setting up an object store by a supported provider: Red Hat OpenShift Data Foundation, MinIO, Amazon S3, Azure Blob Storage, or Google Cloud Storage.
Additionally, opting for object storage requires creating a secret for your object storage bucket in the project that you created for the
TempoMonolithic
instance. You can do this in Workloads → Secrets → Create → From YAML.For more information, see "Object storage setup".
Example secret for Amazon S3 and MinIO storage
Copy to Clipboard Copied! Toggle word wrap Toggle overflow Create a
TempoMonolithic
instance:NoteYou can create multiple
TempoMonolithic
instances in separate projects on the same cluster.- Go to Operators → Installed Operators.
- Select TempoMonolithic → Create TempoMonolithic → YAML view.
In the YAML view, customize the
TempoMonolithic
custom resource (CR).Example
TempoMonolithic
CRCopy to Clipboard Copied! Toggle word wrap Toggle overflow - 1
- This CR creates a
TempoMonolithic
deployment with trace ingestion in the OTLP protocol. - 2
- The project that you have chosen for the
TempoMonolithic
deployment. Project names beginning with theopenshift-
prefix are not permitted. - 3
- Red Hat supports only the custom resource options that are available in the Red Hat OpenShift Distributed Tracing Platform documentation.
- 4
- Specifies the storage for storing traces.
- 5
- Type of storage for storing traces: in-memory storage, a persistent volume, or object storage. The value for a persistent volume is
pv
. The accepted values for object storage ares3
,gcs
, orazure
, depending on the used object store type. The default value ismemory
for thetmpfs
in-memory storage, which is only appropriate for development, testing, demonstrations, and proof-of-concept environments because the data does not persist when the pod is shut down. - 6
- Memory size: For in-memory storage, this means the size of the
tmpfs
volume, where the default is2Gi
. For a persistent volume, this means the size of the persistent volume claim, where the default is10Gi
. For object storage, this means the size of the persistent volume claim for the Tempo Write-Ahead Logging (WAL), where the default is10Gi
. - 7
- Optional: For object storage, the type of object storage. The accepted values are
s3
,gcs
, andazure
, depending on the used object store type. - 8
- Optional: For object storage, the value of the
name
in themetadata
of the storage secret. The storage secret must be in the same namespace as theTempoMonolithic
instance and contain the fields specified in "Table 1. Required secret parameters" in the section "Object storage setup". - 9
- Optional.
- 10
- Optional: Name of a
ConfigMap
object that contains a CA certificate. - 11
- Exposes the Jaeger UI, which visualizes the data, via a route at
http://<gateway_ingress>/api/traces/v1/<tenant_name>/search
. - 12
- Enables creation of the route for the Jaeger UI.
- 13
- Optional.
- 14
- Lists the tenants.
- 15
- The tenant name, which is used as the value for the
X-Scope-OrgId
HTTP header. - 16
- The unique identifier of the tenant. Must be unique throughout the lifecycle of the
TempoMonolithic
deployment. This ID will be added as a prefix to the objects in the object storage. You can reuse the value of the UUID ortempoName
field.
- Select Create.
Verification
-
Use the Project: dropdown list to select the project of the
TempoMonolithic
instance. -
Go to Operators → Installed Operators to verify that the Status of the
TempoMonolithic
instance is Condition: Ready. -
Go to Workloads → Pods to verify that the pod of the
TempoMonolithic
instance is running. Access the Jaeger UI:
Go to Networking → Routes and Ctrl+F to search for
jaegerui
.NoteThe Jaeger UI uses the
tempo-<metadata_name_of_TempoMonolithic_CR>-jaegerui
route.- In the Location column, open the URL to access the Jaeger UI.
When the pod of the
TempoMonolithic
instance is ready, you can send traces to thetempo-<metadata_name_of_TempoMonolithic_CR>:4317
(OTLP/gRPC) andtempo-<metadata_name_of_TempoMonolithic_CR>:4318
(OTLP/HTTP) endpoints inside the cluster.The Tempo API is available at the
tempo-<metadata_name_of_TempoMonolithic_CR>:3200
endpoint inside the cluster.
3.5.2. Installing a TempoMonolithic instance by using the CLI Copia collegamentoCollegamento copiato negli appunti!
The TempoMonolithic
instance 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.
You can install a TempoMonolithic
instance from the command line.
Prerequisites
An active OpenShift CLI (
oc
) session by a cluster administrator with thecluster-admin
role.Tip-
Ensure that your OpenShift CLI (
oc
) version is up to date and matches your OpenShift Container Platform version. Run the
oc login
command:oc login --username=<your_username>
$ oc login --username=<your_username>
Copy to Clipboard Copied! Toggle word wrap Toggle overflow
-
Ensure that your OpenShift CLI (
- You have defined one or more tenants and configured the read and write permissions. For more information, see "Configuring the read permissions for tenants" and "Configuring the write permissions for tenants".
Procedure
Run the following command to create a permitted project of your choice for the
TempoMonolithic
instance that you will create in a subsequent step:Copy to Clipboard Copied! Toggle word wrap Toggle overflow - 1
- Project names beginning with the
openshift-
prefix are not permitted.
Decide which type of supported storage to use for storing traces: in-memory storage, a persistent volume, or object storage.
ImportantObject storage is not included with the Distributed Tracing Platform and requires setting up an object store by a supported provider: Red Hat OpenShift Data Foundation, MinIO, Amazon S3, Azure Blob Storage, or Google Cloud Storage.
Additionally, opting for object storage requires creating a secret for your object storage bucket in the project that you created for the
TempoMonolithic
instance. You can do this by running the following command:oc apply -f - << EOF <object_storage_secret> EOF
$ oc apply -f - << EOF <object_storage_secret> EOF
Copy to Clipboard Copied! Toggle word wrap Toggle overflow For more information, see "Object storage setup".
Example secret for Amazon S3 and MinIO storage
Copy to Clipboard Copied! Toggle word wrap Toggle overflow Create a
TempoMonolithic
instance in the project that you created for it.TipYou can create multiple
TempoMonolithic
instances in separate projects on the same cluster.Customize the
TempoMonolithic
custom resource (CR).Example
TempoMonolithic
CRCopy to Clipboard Copied! Toggle word wrap Toggle overflow - 1
- This CR creates a
TempoMonolithic
deployment with trace ingestion in the OTLP protocol. - 2
- The project that you have chosen for the
TempoMonolithic
deployment. Project names beginning with theopenshift-
prefix are not permitted. - 3
- Red Hat supports only the custom resource options that are available in the Red Hat OpenShift Distributed Tracing Platform documentation.
- 4
- Specifies the storage for storing traces.
- 5
- Type of storage for storing traces: in-memory storage, a persistent volume, or object storage. The value for a persistent volume is
pv
. The accepted values for object storage ares3
,gcs
, orazure
, depending on the used object store type. The default value ismemory
for thetmpfs
in-memory storage, which is only appropriate for development, testing, demonstrations, and proof-of-concept environments because the data does not persist when the pod is shut down. - 6
- Memory size: For in-memory storage, this means the size of the
tmpfs
volume, where the default is2Gi
. For a persistent volume, this means the size of the persistent volume claim, where the default is10Gi
. For object storage, this means the size of the persistent volume claim for the Tempo Write-Ahead Logging (WAL), where the default is10Gi
. - 7
- Optional: For object storage, the type of object storage. The accepted values are
s3
,gcs
, andazure
, depending on the used object store type. - 8
- Optional: For object storage, the value of the
name
in themetadata
of the storage secret. The storage secret must be in the same namespace as theTempoMonolithic
instance and contain the fields specified in "Table 1. Required secret parameters" in the section "Object storage setup". - 9
- Optional.
- 10
- Optional: Name of a
ConfigMap
object that contains a CA certificate. - 11
- Exposes the Jaeger UI, which visualizes the data, via a route at
http://<gateway_ingress>/api/traces/v1/<tenant_name>/search
. - 12
- Enables creation of the route for the Jaeger UI.
- 13
- Optional.
- 14
- Lists the tenants.
- 15
- The tenant name, which is used as the value for the
X-Scope-OrgId
HTTP header. - 16
- The unique identifier of the tenant. Must be unique throughout the lifecycle of the
TempoMonolithic
deployment. This ID will be added as a prefix to the objects in the object storage. You can reuse the value of the UUID ortempoName
field.
Apply the customized CR by running the following command:
oc apply -f - << EOF <tempomonolithic_cr> EOF
$ oc apply -f - << EOF <tempomonolithic_cr> EOF
Copy to Clipboard Copied! Toggle word wrap Toggle overflow
Verification
Verify that the
status
of allTempoMonolithic
components
isRunning
and theconditions
aretype: Ready
by running the following command:oc get tempomonolithic.tempo.grafana.com <metadata_name_of_tempomonolithic_cr> -o yaml
$ oc get tempomonolithic.tempo.grafana.com <metadata_name_of_tempomonolithic_cr> -o yaml
Copy to Clipboard Copied! Toggle word wrap Toggle overflow Run the following command to verify that the pod of the
TempoMonolithic
instance is running:oc get pods
$ oc get pods
Copy to Clipboard Copied! Toggle word wrap Toggle overflow Access the Jaeger UI:
Query the route details for the
tempo-<metadata_name_of_tempomonolithic_cr>-jaegerui
route by running the following command:oc get route
$ oc get route
Copy to Clipboard Copied! Toggle word wrap Toggle overflow -
Open
https://<route_from_previous_step>
in a web browser.
When the pod of the
TempoMonolithic
instance is ready, you can send traces to thetempo-<metadata_name_of_tempomonolithic_cr>:4317
(OTLP/gRPC) andtempo-<metadata_name_of_tempomonolithic_cr>:4318
(OTLP/HTTP) endpoints inside the cluster.The Tempo API is available at the
tempo-<metadata_name_of_tempomonolithic_cr>:3200
endpoint inside the cluster.
Chapter 4. Configuring the Distributed Tracing Platform Copia collegamentoCollegamento copiato negli appunti!
For information about configuring the deprecated Distributed Tracing Platform (Jaeger), see Configuring in the Distributed Tracing Platform (Jaeger) documentation.
The Tempo Operator uses a custom resource definition (CRD) file that defines the architecture and configuration settings for creating and deploying the Distributed Tracing Platform resources. You can install the default configuration or modify the file.
4.1. Configuring back-end storage Copia collegamentoCollegamento copiato negli appunti!
For information about configuring the back-end storage, see Understanding persistent storage and the relevant configuration section for your chosen storage option.
4.2. Introduction to TempoStack configuration parameters Copia collegamentoCollegamento copiato negli appunti!
The TempoStack
custom resource (CR) defines the architecture and settings for creating the Distributed Tracing Platform resources. You can modify these parameters to customize your implementation to your business needs.
Example TempoStack
CR
- 1
- API version to use when creating the object.
- 2
- Defines the kind of Kubernetes object to create.
- 3
- Data that uniquely identifies the object, including a
name
string,UID
, and optionalnamespace
. OpenShift Container Platform automatically generates theUID
and completes thenamespace
with the name of the project where the object is created. - 4
- Name of the TempoStack instance.
- 5
- Contains all of the configuration parameters of the TempoStack instance. When a common definition for all Tempo components is required, define it in the
spec
section. When the definition relates to an individual component, place it in thespec.template.<component>
section. - 6
- Storage is specified at instance deployment. See the installation page for information about storage options for the instance.
- 7
- Defines the compute resources for the Tempo container.
- 8
- Integer value for the number of ingesters that must acknowledge the data from the distributors before accepting a span.
- 9
- Configuration options for retention of traces. The default value is
48h
. - 10
- Configuration options for the Tempo
distributor
component. - 11
- Configuration options for the Tempo
ingester
component. - 12
- Configuration options for the Tempo
compactor
component. - 13
- Configuration options for the Tempo
querier
component. - 14
- Configuration options for the Tempo
query-frontend
component. - 15
- Configuration options for the Tempo
gateway
component. - 16
- Limits ingestion and query rates.
- 17
- Defines ingestion rate limits.
- 18
- Defines query rate limits.
- 19
- Configures operands to handle telemetry data.
- 20
- Configures search capabilities.
- 21
- Defines whether or not this CR is managed by the Operator. The default value is
managed
.
Parameter | Description | Values | Default value |
---|---|---|---|
| API version to use when creating the object. |
|
|
| Defines the kind of the Kubernetes object to create. |
| |
|
Data that uniquely identifies the object, including a |
OpenShift Container Platform automatically generates the | |
| Name for the object. | Name of your TempoStack instance. |
|
| Specification for the object to be created. |
Contains all of the configuration parameters for your TempoStack instance. When a common definition for all Tempo components is required, it is defined under the | N/A |
| Resources assigned to the TempoStack instance. | ||
| Storage size for ingester PVCs. | ||
| Configuration for the replication factor. | ||
| Configuration options for retention of traces. | ||
| Configuration options that define the storage. | ||
| Configuration options for the Tempo distributor. | ||
| Configuration options for the Tempo ingester. | ||
| Configuration options for the Tempo compactor. | ||
| Configuration options for the Tempo querier. | ||
| Configuration options for the Tempo query frontend. | ||
| Configuration options for the Tempo gateway. |
4.3. Query configuration options Copia collegamentoCollegamento copiato negli appunti!
Two components of the Distributed Tracing Platform, the querier and query frontend, manage queries. You can configure both of these components.
The querier component finds the requested trace ID in the ingesters or back-end storage. Depending on the set parameters, the querier component can query both the ingesters and pull bloom or indexes from the back end to search blocks in object storage. The querier component exposes an HTTP endpoint at GET /querier/api/traces/<trace_id>
, but it is not expected to be used directly. Queries must be sent to the query frontend.
Parameter | Description | Values |
---|---|---|
| The simple form of the node-selection constraint. | type: object |
| The number of replicas to be created for the component. | type: integer; format: int32 |
| Component-specific pod tolerations. | type: array |
The query frontend component is responsible for sharding the search space for an incoming query. The query frontend exposes traces via a simple HTTP endpoint: GET /api/traces/<trace_id>
. Internally, the query frontend component splits the blockID
space into a configurable number of shards and then queues these requests. The querier component connects to the query frontend component via a streaming gRPC connection to process these sharded queries.
Parameter | Description | Values |
---|---|---|
| Configuration of the query frontend component. | type: object |
| The simple form of the node selection constraint. | type: object |
| The number of replicas to be created for the query frontend component. | type: integer; format: int32 |
| Pod tolerations specific to the query frontend component. | type: array |
| The options specific to the Jaeger Query component. | type: object |
|
When | type: boolean |
| The options for the Jaeger Query ingress. | type: object |
| The annotations of the ingress object. | type: object |
| The hostname of the ingress object. | type: string |
| The name of an IngressClass cluster resource. Defines which ingress controller serves this ingress resource. | type: string |
| The options for the OpenShift route. | type: object |
|
The termination type. The default is | type: string (enum: insecure, edge, passthrough, reencrypt) |
|
The type of ingress for the Jaeger Query UI. The supported types are | type: string (enum: ingress, route) |
| The monitor tab configuration. | type: object |
|
Enables the monitor tab in the Jaeger console. The | type: boolean |
|
The endpoint to the Prometheus instance that contains the span rate, error, and duration (RED) metrics. For example, | type: string |
Example configuration of the query frontend component in a TempoStack
CR
4.4. Configuring the UI Copia collegamentoCollegamento copiato negli appunti!
You can use the distributed tracing UI plugin of the Cluster Observability Operator (COO) as the user interface (UI) for the Red Hat OpenShift Distributed Tracing Platform. For more information about installing and using the distributed tracing UI plugin, see "Distributed tracing UI plugin" in Cluster Observability Operator.
4.5. Configuring the Monitor tab in Jaeger UI Copia collegamentoCollegamento copiato negli appunti!
You can have the request rate, error, and duration (RED) metrics extracted from traces and visualized through the Jaeger Console in the Monitor tab of the OpenShift Container Platform web console. The metrics are derived from spans in the OpenTelemetry Collector that are scraped from the Collector by Prometheus, which you can deploy in your user-workload monitoring stack. The Jaeger UI queries these metrics from the Prometheus endpoint and visualizes them.
Prerequisites
- You have configured the permissions and tenants for the Distributed Tracing Platform. For more information, see "Configuring the permissions and tenants".
Procedure
In the
OpenTelemetryCollector
custom resource of the OpenTelemetry Collector, enable the Spanmetrics Connector (spanmetrics
), which derives metrics from traces and exports the metrics in the Prometheus format.Example
OpenTelemetryCollector
custom resource for span REDCopy to Clipboard Copied! Toggle word wrap Toggle overflow - 1
- Creates the
ServiceMonitor
custom resource to enable scraping of the Prometheus exporter. - 2
- The Spanmetrics connector receives traces and exports metrics.
- 3
- The OTLP receiver to receive spans in the OpenTelemetry protocol.
- 4
- The Prometheus exporter is used to export metrics in the Prometheus format.
- 5
- The resource attributes are dropped by default.
- 6
- The Spanmetrics connector is configured as exporter in traces pipeline.
- 7
- The Spanmetrics connector is configured as receiver in metrics pipeline.
In the
TempoStack
custom resource, enable the Monitor tab and set the Prometheus endpoint to the Thanos querier service to query the data from your user-defined monitoring stack.Example
TempoStack
custom resource with the enabled Monitor tabCopy to Clipboard Copied! Toggle word wrap Toggle overflow - 1
- Enables the monitoring tab in the Jaeger console.
- 2
- The service name for Thanos Querier from user-workload monitoring.
- 3
- Optional: The metrics namespace on which the Jaeger query retrieves the Prometheus metrics. Include this line only if you are using an OpenTelemetry Collector version earlier than 0.109.0. If you are using an OpenTelemetry Collector version 0.109.0 or later, omit this line.
Optional: Use the span RED metrics generated by the
spanmetrics
connector with alerting rules. For example, for alerts about a slow service or to define service level objectives (SLOs), the connector creates aduration_bucket
histogram and thecalls
counter metric. These metrics have labels that identify the service, API name, operation type, and other attributes.Expand Table 4.4. Labels of the metrics created in the spanmetrics connector Label Description Values service_name
Service name set by the
otel_service_name
environment variable.frontend
span_name
Name of the operation.
-
/
-
/customer
span_kind
Identifies the server, client, messaging, or internal operation.
-
SPAN_KIND_SERVER
-
SPAN_KIND_CLIENT
-
SPAN_KIND_PRODUCER
-
SPAN_KIND_CONSUMER
-
SPAN_KIND_INTERNAL
Example
PrometheusRule
custom resource that defines an alerting rule for SLO when not serving 95% of requests within 2000ms on the front-end serviceCopy to Clipboard Copied! Toggle word wrap Toggle overflow - 1
- The expression for checking if 95% of the front-end server response time values are below 2000 ms. The time range (
[5m]
) must be at least four times the scrape interval and long enough to accommodate a change in the metric.
-
4.6. Configuring the receiver TLS Copia collegamentoCollegamento copiato negli appunti!
The custom resource of your TempoStack or TempoMonolithic instance supports configuring the TLS for receivers by using user-provided certificates or OpenShift’s service serving certificates.
4.6.1. Receiver TLS configuration for a TempoStack instance Copia collegamentoCollegamento copiato negli appunti!
You can provide a TLS certificate in a secret or use the service serving certificates that are generated by OpenShift Container Platform.
To provide a TLS certificate in a secret, configure it in the
TempoStack
custom resource.NoteThis feature is not supported with the enabled Tempo Gateway.
TLS for receivers and using a user-provided certificate in a secret
Copy to Clipboard Copied! Toggle word wrap Toggle overflow Alternatively, you can use the service serving certificates that are generated by OpenShift Container Platform.
NoteMutual TLS authentication (mTLS) is not supported with this feature.
TLS for receivers and using the service serving certificates that are generated by OpenShift Container Platform
Copy to Clipboard Copied! Toggle word wrap Toggle overflow - 1
- Sufficient configuration for the TLS at the Tempo Distributor.
4.6.2. Receiver TLS configuration for a TempoMonolithic instance Copia collegamentoCollegamento copiato negli appunti!
You can provide a TLS certificate in a secret or use the service serving certificates that are generated by OpenShift Container Platform.
To provide a TLS certificate in a secret, configure it in the
TempoMonolithic
custom resource.NoteThis feature is not supported with the enabled Tempo Gateway.
TLS for receivers and using a user-provided certificate in a secret
Copy to Clipboard Copied! Toggle word wrap Toggle overflow Alternatively, you can use the service serving certificates that are generated by OpenShift Container Platform.
NoteMutual TLS authentication (mTLS) is not supported with this feature.
TLS for receivers and using the service serving certificates that are generated by OpenShift Container Platform
Copy to Clipboard Copied! Toggle word wrap Toggle overflow - 1
- Minimal configuration for the TLS at the Tempo Distributor.
4.7. Configuring the query RBAC Copia collegamentoCollegamento copiato negli appunti!
As an administrator, you can set up the query role-based access control (RBAC) to filter the span attributes for your users by the namespaces for which you granted them permissions.
When you enable the query RBAC, users can still access traces from all namespaces, and the service.name
and k8s.namespace.name
attributes are also visible to all users.
Prerequisites
An active OpenShift CLI (
oc
) session by a cluster administrator with thecluster-admin
role.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
Enable multitenancy and query RBAC in the
TempoStack
custom resource (CR), for example:Copy to Clipboard Copied! Toggle word wrap Toggle overflow Create a cluster role and cluster role binding to grant the target users the permissions to access the tenant that you specified in the
TempoStack
CR, for example:Copy to Clipboard Copied! Toggle word wrap Toggle overflow Grant the target users the permissions to read attributes for the project. You can do this by running the following command:
oc adm policy add-role-to-user view <username> -n <project>
$ oc adm policy add-role-to-user view <username> -n <project>
Copy to Clipboard Copied! Toggle word wrap Toggle overflow
4.8. Using taints and tolerations Copia collegamentoCollegamento copiato negli appunti!
To schedule the TempoStack pods on dedicated nodes, see How to deploy the different TempoStack components on infra nodes using nodeSelector and tolerations in OpenShift 4.
4.9. Configuring monitoring and alerts Copia collegamentoCollegamento copiato negli appunti!
The Tempo Operator supports monitoring and alerts about each TempoStack component such as distributor, ingester, and so on, and exposes upgrade and operational metrics about the Operator itself.
4.9.1. Configuring the TempoStack metrics and alerts Copia collegamentoCollegamento copiato negli appunti!
You can enable metrics and alerts of TempoStack instances.
Prerequisites
- Monitoring for user-defined projects is enabled in the cluster.
Procedure
To enable metrics of a TempoStack instance, set the
spec.observability.metrics.createServiceMonitors
field totrue
:Copy to Clipboard Copied! Toggle word wrap Toggle overflow To enable alerts for a TempoStack instance, set the
spec.observability.metrics.createPrometheusRules
field totrue
:Copy to Clipboard Copied! Toggle word wrap Toggle overflow
Verification
You can use the Administrator view of the web console to verify successful configuration:
-
Go to Observe → Targets, filter for Source: User, and check that ServiceMonitors in the format
tempo-<instance_name>-<component>
have the Up status. - To verify that alerts are set up correctly, go to Observe → Alerting → Alerting rules, filter for Source: User, and check that the Alert rules for the TempoStack instance components are available.
4.9.2. Configuring the Tempo Operator metrics and alerts Copia collegamentoCollegamento copiato negli appunti!
When installing the Tempo Operator from the web console, you can select the Enable Operator recommended cluster monitoring on this Namespace checkbox, which enables creating metrics and alerts of the Tempo Operator.
If the checkbox was not selected during installation, you can manually enable metrics and alerts even after installing the Tempo Operator.
Procedure
-
Add the
openshift.io/cluster-monitoring: "true"
label in the project where the Tempo Operator is installed, which isopenshift-tempo-operator
by default.
Verification
You can use the Administrator view of the web console to verify successful configuration:
-
Go to Observe → Targets, filter for Source: Platform, and search for
tempo-operator
, which must have the Up status. - To verify that alerts are set up correctly, go to Observe → Alerting → Alerting rules, filter for Source: Platform, and locate the Alert rules for the Tempo Operator.
Chapter 5. Troubleshooting the Distributed Tracing Platform Copia collegamentoCollegamento copiato negli appunti!
You can diagnose and fix issues in TempoStack or TempoMonolithic instances by using various troubleshooting methods.
5.1. Collecting diagnostic data from the command line Copia collegamentoCollegamento copiato negli appunti!
When submitting a support case, it is helpful to include diagnostic information about your cluster to Red Hat Support. You can use the oc adm must-gather
tool to gather diagnostic data for resources of various types, such as TempoStack
or TempoMonolithic
, and the created resources like Deployment
, Pod
, or ConfigMap
. The oc adm must-gather
tool creates a new pod that collects this data.
Procedure
From the directory where you want to save the collected data, run the
oc adm must-gather
command to collect the data:oc adm must-gather --image=ghcr.io/grafana/tempo-operator/must-gather -- \ /usr/bin/must-gather --operator-namespace <operator_namespace>
$ oc adm must-gather --image=ghcr.io/grafana/tempo-operator/must-gather -- \ /usr/bin/must-gather --operator-namespace <operator_namespace>
1 Copy to Clipboard Copied! Toggle word wrap Toggle overflow - 1
- The default namespace where the Operator is installed is
openshift-tempo-operator
.
Verification
- Verify that the new directory is created and contains the collected data.
Chapter 6. Upgrading Copia collegamentoCollegamento copiato negli appunti!
For information about upgrading the deprecated Distributed Tracing Platform (Jaeger), see Upgrading in the Distributed Tracing Platform (Jaeger) documentation.
For version upgrades, the Tempo Operator uses the Operator Lifecycle Manager (OLM), which controls installation, upgrade, and role-based access control (RBAC) of Operators in a cluster.
The OLM runs in the OpenShift Container Platform by default. The OLM queries for available Operators as well as upgrades for installed Operators.
When the Tempo Operator is upgraded to the new version, it scans for running TempoStack instances that it manages and upgrades them to the version corresponding to the Operator’s new version.
Chapter 7. Removing the Distributed Tracing Platform Copia collegamentoCollegamento copiato negli appunti!
For information about removing the deprecated Distributed Tracing Platform (Jaeger), see Removing in the Distributed Tracing Platform (Jaeger) documentation.
The steps for removing the Red Hat OpenShift Distributed Tracing Platform from an OpenShift Container Platform cluster are as follows:
- Shut down all Distributed Tracing Platform pods.
- Remove any TempoStack instances.
- Remove the Tempo Operator.
7.1. Removing by using the web console Copia collegamentoCollegamento copiato negli appunti!
You can remove a TempoStack instance in the Administrator view of the web console.
Prerequisites
-
You are logged in to the OpenShift Container Platform web console as a cluster administrator with the
cluster-admin
role. -
For Red Hat OpenShift Dedicated, you must be logged in using an account with the
dedicated-admin
role.
Procedure
- Go to Operators → Installed Operators → Tempo Operator → TempoStack.
-
To remove the TempoStack instance, select
→ Delete TempoStack → Delete.
- Optional: Remove the Tempo Operator.
7.2. Removing by using the CLI Copia collegamentoCollegamento copiato negli appunti!
You can remove a TempoStack instance on the command line.
Prerequisites
An active OpenShift CLI (
oc
) session by a cluster administrator with thecluster-admin
role.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
Get the name of the TempoStack instance by running the following command:
oc get deployments -n <project_of_tempostack_instance>
$ oc get deployments -n <project_of_tempostack_instance>
Copy to Clipboard Copied! Toggle word wrap Toggle overflow Remove the TempoStack instance by running the following command:
oc delete tempo <tempostack_instance_name> -n <project_of_tempostack_instance>
$ oc delete tempo <tempostack_instance_name> -n <project_of_tempostack_instance>
Copy to Clipboard Copied! Toggle word wrap Toggle overflow - Optional: Remove the Tempo Operator.
Verification
Run the following command to verify that the TempoStack instance is not found in the output, which indicates its successful removal:
oc get deployments -n <project_of_tempostack_instance>
$ oc get deployments -n <project_of_tempostack_instance>
Copy to Clipboard Copied! Toggle word wrap Toggle overflow
Chapter 8. Distributed Tracing Platform (Jaeger) Copia collegamentoCollegamento copiato negli appunti!
8.1. Installing the Distributed Tracing Platform (Jaeger) Copia collegamentoCollegamento copiato negli appunti!
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.
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
ServiceMeshControlPlane
and 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.
8.1.1. Prerequisites Copia collegamentoCollegamento copiato negli appunti!
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.12 overview.
Install OpenShift Container Platform 4.12.
-
Install the version of the
oc
CLI tool that matches your OpenShift Container Platform version and add it to your path. -
An account with the
cluster-admin
role.
8.1.2. Red Hat OpenShift Distributed Tracing Platform installation overview Copia collegamentoCollegamento copiato negli appunti!
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.
8.1.3. Installing the OpenShift Elasticsearch Operator Copia collegamentoCollegamento copiato negli appunti!
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-admin
role. If you use Red Hat OpenShift Dedicated, you must have an account with thededicated-admin
role.
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-admin
role. If you use Red Hat OpenShift Dedicated, you must have an account with thededicated-admin
role. - 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-redhat
project and makes the Operator available to all projects in the cluster.NoteThe 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-operators
namespace.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.
NoteThe 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-redhat
project. Wait for the InstallSucceeded status of the OpenShift Elasticsearch Operator before continuing.
8.1.4. Installing the Red Hat OpenShift Distributed Tracing Platform Operator Copia collegamentoCollegamento copiato negli appunti!
You can install the Red Hat OpenShift Distributed Tracing Platform Operator through the OperatorHub.
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-admin
role. If you use Red Hat OpenShift Dedicated, you must have an account with thededicated-admin
role. - If you require persistent storage, you must install the OpenShift Elasticsearch Operator before installing the Red Hat OpenShift Distributed Tracing Platform Operator.
Procedure
-
Log in to the OpenShift Container Platform web console as a user with the
cluster-admin
role. If you use Red Hat OpenShift Dedicated, you must have an account with thededicated-admin
role. - Navigate to Operators → OperatorHub.
- Search for the Red Hat OpenShift Distributed Tracing Platform Operator by entering distributed tracing platform in the search field.
- Select the Red Hat OpenShift Distributed Tracing Platform Operator, which is provided by Red Hat, to display information about the Operator.
- Click Install.
- For the Update channel on the Install Operator page, select stable to automatically update the Operator when new versions are released.
-
Accept the default All namespaces on the cluster (default). This installs the Operator in the default
openshift-operators
project and makes the Operator available to all projects in the cluster. Accept the default Automatic approval strategy.
NoteIf you accept this default, the Operator Lifecycle Manager (OLM) automatically upgrades the running instance of this Operator when a new version of the Operator becomes available.
If you select Manual updates, the OLM creates an update request when a new version of the Operator becomes available. To update the Operator to the new version, you must then manually approve the update request as a cluster administrator. The Manual approval strategy requires a cluster administrator to manually approve Operator installation and subscription.
- Click Install.
- Navigate to Operators → Installed Operators.
-
On the Installed Operators page, select the
openshift-operators
project. Wait for the Succeeded status of the Red Hat OpenShift Distributed Tracing Platform Operator before continuing.
8.2. Configuring the Distributed Tracing Platform (Jaeger) Copia collegamentoCollegamento copiato negli appunti!
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.
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.
8.2.1. Supported deployment strategies Copia collegamentoCollegamento copiato negli appunti!
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.
NoteIn-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
production
orstreaming
strategies, 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.
8.2.2. Deploying the Distributed Tracing Platform default strategy from the web console Copia collegamentoCollegamento copiato negli appunti!
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-admin
role.
Procedure
-
Log in to the OpenShift Container Platform web console as a user with the
cluster-admin
role. Create a new project, for example
tracing-system
.NoteIf you are installing as part of Service Mesh, the Distributed Tracing Platform resources must be installed in the same namespace as the
ServiceMeshControlPlane
resource, for exampleistio-system
.- Go to Home → Projects.
- Click Create Project.
-
Enter
tracing-system
in the Name field. - Click Create.
- Navigate to Operators → Installed Operators.
-
If necessary, select
tracing-system
from 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.
8.2.2.1. Deploying the Distributed Tracing Platform default strategy from the CLI Copia collegamentoCollegamento copiato negli appunti!
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-admin
role.
Procedure
Log in to the OpenShift Container Platform CLI as a user with the
cluster-admin
role 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-system
by 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.yaml
that 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
8.2.3. Deploying the Distributed Tracing Platform production strategy from the web console Copia collegamentoCollegamento copiato negli appunti!
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-admin
role.
Procedure
-
Log in to the OpenShift Container Platform web console as a user with the
cluster-admin
role. Create a new project, for example
tracing-system
.NoteIf you are installing as part of Service Mesh, the Distributed Tracing Platform resources must be installed in the same namespace as the
ServiceMeshControlPlane
resource, for exampleistio-system
.- Navigate to Home → Projects.
- Click Create Project.
-
Enter
tracing-system
in the Name field. - Click Create.
- Navigate to Operators → Installed Operators.
-
If necessary, select
tracing-system
from 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-one
YAML 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.
8.2.3.1. Deploying the Distributed Tracing Platform production strategy from the CLI Copia collegamentoCollegamento copiato negli appunti!
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-admin
role.
Procedure
Log in to the OpenShift CLI (
oc
) as a user with thecluster-admin
role 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-system
by 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.yaml
that 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
8.2.4. Deploying the Distributed Tracing Platform streaming strategy from the web console Copia collegamentoCollegamento copiato negli appunti!
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-admin
role.
Procedure
-
Log in to the OpenShift Container Platform web console as a user with the
cluster-admin
role. Create a new project, for example
tracing-system
.NoteIf you are installing as part of Service Mesh, the Distributed Tracing Platform resources must be installed in the same namespace as the
ServiceMeshControlPlane
resource, for exampleistio-system
.- Navigate to Home → Projects.
- Click Create Project.
-
Enter
tracing-system
in the Name field. - Click Create.
- Navigate to Operators → Installed Operators.
-
If necessary, select
tracing-system
from 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-one
YAML 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.
8.2.4.1. Deploying the Distributed Tracing Platform streaming strategy from the CLI Copia collegamentoCollegamento copiato negli appunti!
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-admin
role.
Procedure
Log in to the OpenShift CLI (
oc
) as a user with thecluster-admin
role 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-system
by 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.yaml
that 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
8.2.5. Validating your deployment Copia collegamentoCollegamento copiato negli appunti!
8.2.5.1. Accessing the Jaeger console Copia collegamentoCollegamento copiato negli appunti!
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-admin
role. - 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
jaeger
route. 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-admin
role by running the following command. If you use Red Hat OpenShift Dedicated, you must have an account with thededicated-admin
role.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-system
is 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.
8.2.6. Customizing your deployment Copia collegamentoCollegamento copiato negli appunti!
8.2.6.1. Deployment best practices Copia collegamentoCollegamento copiato negli appunti!
- 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.
8.2.6.2. Distributed tracing default configuration options Copia collegamentoCollegamento copiato negli appunti!
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-inmemory
8.2.6.3. Using taints and tolerations Copia collegamentoCollegamento copiato negli appunti!
To schedule the Jaeger and Elasticsearch pods on dedicated nodes, see How to deploy the different Jaeger components on infra nodes using nodeSelector and tolerations in OpenShift 4.
8.2.6.4. Jaeger Collector configuration options Copia collegamentoCollegamento copiato negli appunti!
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 | |
|
To accept OTLP/HTTP, explicitly enable the |
8.2.6.5. Distributed tracing sampling configuration options Copia collegamentoCollegamento copiato negli appunti!
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.param
property. For example, usingsampling.param=0.1
samples 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.0
samples 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
8.2.6.6. Distributed tracing storage configuration options Copia collegamentoCollegamento copiato negli appunti!
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 * * *" |
8.2.6.6.1. Auto-provisioning an Elasticsearch instance Copia collegamentoCollegamento copiato negli appunti!
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:type
is set toelasticsearch
-
spec.storage.elasticsearch.doNotProvision
set tofalse
-
spec.storage.options.es.server-urls
is not defined, that is, there is no connection to an Elasticsearch instance that was not provisioned by the OpenShift 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 OpenShift 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 AWS
gp2
with5Gi
size. When no value is specified, Distributed Tracing Platform (Jaeger) usesemptyDir
. The OpenShift Elasticsearch Operator provisionsPersistentVolumeClaim
andPersistentVolume
which 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.
8.2.6.6.2. Connecting to an existing Elasticsearch instance Copia collegamentoCollegamento copiato negli appunti!
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 OpenShift 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.doNotProvision
set totrue
-
spec.storage.options.es.server-urls
has a value -
spec.storage.elasticsearch.name
has 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.
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.
8.2.6.7. Managing certificates with Elasticsearch Copia collegamentoCollegamento copiato negli appunti!
You can create and manage certificates using the OpenShift Elasticsearch Operator. Managing certificates using the OpenShift 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 OpenShift 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
- The Red Hat OpenShift Service Mesh Operator is installed.
- The {logging-title} is installed with default configuration in your cluster.
-
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 OpenShift Elasticsearch Operator and the Red Hat OpenShift Distributed Tracing Platform (Jaeger) Operator injects the certificates.
8.2.6.8. Query configuration options Copia collegamentoCollegamento copiato negli appunti!
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
8.2.6.9. Ingester configuration options Copia collegamentoCollegamento copiato negli appunti!
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
8.2.7. Injecting sidecars Copia collegamentoCollegamento copiato negli appunti!
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.
8.2.7.1. Automatically injecting sidecars Copia collegamentoCollegamento copiato negli appunti!
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 string
true
or to the Jaeger instance name.
When the sidecar is injected, the agent can then be accessed at its default location on localhost
.
8.2.7.2. Manually injecting sidecars Copia collegamentoCollegamento copiato negli appunti!
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.
8.3. Upgrading the Distributed Tracing Platform (Jaeger) Copia collegamentoCollegamento copiato negli appunti!
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.
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.
8.4. Removing the Distributed Tracing Platform (Jaeger) Copia collegamentoCollegamento copiato negli appunti!
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.
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.
8.4.1. Removing a Distributed Tracing Platform (Jaeger) instance by using the web console Copia collegamentoCollegamento copiato negli appunti!
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-admin
role.
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.
- In the confirmation message, click Delete.
8.4.2. Removing a Distributed Tracing Platform (Jaeger) instance by using the CLI Copia collegamentoCollegamento copiato negli appunti!
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 thecluster-admin
role.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 deployments
command 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
8.4.3. Removing the Red Hat OpenShift Distributed Tracing Platform Operators Copia collegamentoCollegamento copiato negli appunti!
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.
Legal Notice
Copia collegamentoCollegamento copiato negli appunti!
Copyright © 2025 Red Hat
OpenShift documentation is licensed under the Apache License 2.0 (https://www.apache.org/licenses/LICENSE-2.0).
Modified versions must remove all Red Hat trademarks.
Portions adapted from https://github.com/kubernetes-incubator/service-catalog/ with modifications by Red Hat.
Red Hat, Red Hat Enterprise Linux, the Red Hat logo, the Shadowman logo, JBoss, OpenShift, Fedora, the Infinity logo, and RHCE are trademarks of Red Hat, Inc., registered in the United States and other countries.
Linux® is the registered trademark of Linus Torvalds in the United States and other countries.
Java® is a registered trademark of Oracle and/or its affiliates.
XFS® is a trademark of Silicon Graphics International Corp. or its subsidiaries in the United States and/or other countries.
MySQL® is a registered trademark of MySQL AB in the United States, the European Union and other countries.
Node.js® is an official trademark of Joyent. Red Hat Software Collections is not formally related to or endorsed by the official Joyent Node.js open source or commercial project.
The OpenStack® Word Mark and OpenStack logo are either registered trademarks/service marks or trademarks/service marks of the OpenStack Foundation, in the United States and other countries and are used with the OpenStack Foundation’s permission. We are not affiliated with, endorsed or sponsored by the OpenStack Foundation, or the OpenStack community.
All other trademarks are the property of their respective owners.