Releases: grafana/tempo-operator
Release v0.16.0
🛑 Breaking changes 🛑
-
tempostack, tempomonolithic
: Ensure the operator does not grant additional permissions when enabling OpenShift tenancy mode (resolves CVE-2025-2786) (#1145)
Ensure the permissions the operator is granting to the Tempo Service Account
do not exceed the permissions of the user creating (or modifying) the Tempo instance
when enabling OpenShift tenancy mode.To enable the OpenShift tenancy mode, the user must have permissions to create
TokenReview
andSubjectAccessReview
.This breaking change does not affect existing Tempo instances in the cluster.
However, the required permissions are now mandatory when creating or modifying a TempoStack or TempoMonolithic CR.
💡 Enhancements 💡
-
tempostack, tempomonolithic
: Add short live token authentication for Azure Blob Storage (#1206)
For use short live token on Azure, the secret should contain the following configuration:data: container: # Azure blob storage container name account_name: # Azure blob storage account name client_id: # Azure managed identity clientID tenant_id: # Azure tenant ID in which the managed identity lives. audience: # (optional) Audience of the token, default to api://AzureADTokenExchange
-
tempostack, tempomonolithic
: Support for AWS STS via cloudcredential operator (#1159) -
tempostack, tempomonolithic
: Add support for GCS Shot Live Token authentication. (#1141)
Now storage secret for GCS can containdata: bucketname: # Bucket name iam_sa: # a name for your the Google IAM service account iam_sa_project_id: # The project ID for your IAM service account.
-
tempostack, tempomonolithic
: Set GOMEMLIMIT to 80% of memory limit, if any (#1196)
This golang variable indicate to GoLang GC to be more aggressive when it is reaching out the
memory limits. This is a soft limit, so still can produce OOM, but reduces the possibility. -
operator
: Kubernetes 1.32 enablement (#1157) -
tempomonolithic
: Watch storage secrets for tempo monolithic (#1181)
🧰 Bug fixes 🧰
-
tempostack, tempomonolithic
: Add parameter to set audience in ID token for GCP Workload Identity Federation (#1209)
Now that GCS token allow to set the audience, the secret configuration required channged, now it will require
the following:data: bucketname: # GCS Bucket name audience: # (Optional) default to openshift key.json: # Credential file generated using gclient
File key.json can be created using :
gcloud iam workload-identity-pools create-cred-config \ "projects/<PROJECT_NUMBER>/locations/global/workloadIdentityPools/<POOL_ID>/providers/<PROVIDER_ID>" \ --service-account="<SERVICE_ACCOUNT_EMAIL>" \ --credential-source-file=/var/run/secrets/storage/serviceaccount/token \ --credential-source-type=text \ --output-file="/tmp/key.json"
credential-source-file= Should be pointing to
/var/run/secrets/storage/serviceaccount/token
which is the locationn
operator mounts the projected volume. -
tempostack, tempomonolithic
: Add namespace suffix to ClusterRole and ClusterRoleBinding of gateway (#1146)
This resolves a naming conflict of the ClusterRole and ClusterRoleBinding when two TempoStack/TempoMonolithic instances with the same name, but in different namespaces are created.
Only relevant when using multi-tenancy with OpenShift mode. -
tempostack, tempomonolithic
: Fix pruning of cluster-scoped resources (#1168)
Previously, when a non-multitenant TempoStack instance was created using the same name as an existing multitenant TempoStack instance, the operator erroneously deleted the Gateway ClusterRole and ClusterRoleBinding associated with the multitenant instance.With this change, cluster-scoped resources get an additional label
app.kubernetes.io/namespace
to signify the namespace of the TempoStack owning this cluster-scoped resource. -
tempostack, tempomonolithic
: Cleanup gateway cluster roles and bindings after deleting tempo instance (#1190)
Now the operator uses finalizer to clean up the cluster roles and bindings after deleting the tempo instance. -
tempostack, tempomonolithic
: Allow OpenShift cluster admins to see all attributes when RBAC is enabled. (#1185)
This change removes--opa.admin-groups=system:cluster-admins,cluster-admin,dedicated-admin
from the OpenShift OPA configuration. This configures the OPA to always return
all user's accessible namespaces required by the RBAC feature. -
tempostack, tempomonolithic
: Don't set --opa.matcher=kubernetes_namespace_name when query RBAC is disabled (#1176) -
tempostack
: Fix unimplemented per tenant retention and fix per tenant overrides after tempo 2.3 (#1134)
In tempo 2.3 https://github.com/grafana/tempo/blob/main/CHANGELOG.md#v230--2023-10-30 they changes the overrides config
which was not properly implemented in the operator.This patch also adds support for per tenant retention which was not implemented.
-
tempostack, tempomonolithic
: Assign a percentage of the resources to oauth-proxy if resources are not specified, fixed the name (#1107) -
tempostack
: Limit granted permissions of the Tempo Service Account when enabling the Jaeger UI Monitor tab on OpenShift (resolves CVE-2025-2842) (#1144)
Previously, the operator assigned thecluster-monitoring-view
ClusterRole to the Tempo Service Account
when the Prometheus endpoint of the Jaeger UI Monitor tab is set to the Thanos Querier on OpenShift.With this change, the operator limits the granted permissions to only view metrics of the namespace of the Tempo instance.
Additionally, the recommended port of the Thanos Querier service changed from9091
to9092
(tenancy-aware port):
.spec.template.queryFrontend.jaegerQuery.monitorTab.prometheusEndpoint: https://thanos-querier.openshift-monitoring.svc.cluster.local:9092
.All existing installations, which have the Thanos Querier configured at port 9091, will be upgraded automatically to use port 9092.
-
tempostack, tempomonolithic
: Update Tempo to 2.7.2 (#1149)
Components
- Tempo: v2.7.2
Support
This release supports Kubernetes 1.25 to 1.32.
Release v0.15.3
💡 Enhancements 💡
-
tempomonolithic
: Add support for query RBAC (#1131)
This feature allows users to apply query RBAC in the multitenancy mode.
The RBAC allows filtering span/resource/scope attributes and events based on the namespaces which a user querying the data can access.
For instance, a user can only see attributes from namespaces it can access.spec: query: rbac: enabled: true
Components
- Tempo: v2.7.1
Release v0.15.2
Components
- Tempo: v2.7.1
Release v0.15.1
Components
- Tempo: v2.7.1
Release v0.15.0
🛑 Breaking changes 🛑
-
tempostack, tempomonolithic
: Update Tempo to 2.7.0 (#1110)
Update Tempo to 2.7.0 https://github.com/grafana/tempo/releases/tag/v2.7.0
The Tempo instrumentation changed from Jaeger to OpenTelemetry with OTLP/http exporter.The
spec.observability.tracing.jaeger_agent_endpoint
is deprecated in favor ofspec.observability.tracing.otlp_http_endpoint
.spec: observability: tracing: jaeger_agent_endpoint: # Deprecated! sampling_fraction: "1" otlp_http_endpoint: http://localhost:4320
💡 Enhancements 💡
-
tempostack
: Add support for query RBAC when Gateway/multitenancy is used. (#1100)
This feature allows users to apply query RBAC in the multitenancy mode.
The RBAC allows filtering span/resource/scope attributes and events based on the namespaces which a user querying the data can access.
For instance, a user can only see attributes from namespaces it can access.spec: template: gateway: enabled: true rbac: enabled: true
-
operator
: Remove kube-rbac-proxy (#1094)
The image won't be available and won't be mantained, switched to use WithAuthenticationAndAuthorization
🧰 Bug fixes 🧰
tempostack
: Include insecure option and tls options when STS S3 token is enabled (#1109)tempostack, tempomonolithic
: Assign a percentage of the resources to oauth-proxy if resources are not specified (#1107)
Components
- Tempo: v2.7.0
Release v0.14.2
🧰 Bug fixes 🧰
tempostack
: Use default Jaeger RED metrics namespace if field is unset (#1096)
Use the default Jaeger RED metrics namespace if.spec.template.queryFrontend.jaegerQuery.monitorTab.redMetricsNamespace
is not set.
Before Jaeger 1.62 the default namespace was empty, since Jaeger 1.62 (shipped in Tempo Operator v0.14.0) the default namespace is "traces_span_metrics".
Before OpenTelemetry Collector v0.109.0 the default namespace of the spanmetrics connector was empty, since OpenTelemetry Collector v0.109.0 the default namespace is "traces_span_metrics".
Components
- Tempo: v2.6.1
Release v0.14.1
🧰 Bug fixes 🧰
tempostack
: Fix enabling.spec.observability.tracing
with multi-tenancy on OpenShift (#1081)tempostack, tempomonolithic
: Register missing Jaeger UI routes (#1082)
Without these routes, hitting refresh on the trace detail, system architecture or monitor page of Jaeger UI results in a 404 when multi-tenancy is enabled.
Components
- Tempo: v2.6.1
Release v0.14.0
🛑 Breaking changes 🛑
-
tempostack
: Use new default metrics namespace/prefix for span RED metrics in Jaeger query. (#1072)
Use the new RED metrics default namespacetraces.span.metrics
for retrieval from Prometheus.
Since OpenTelemetry Collector version 0.109.0 the default namespace is set to traces.span.metrics.
The namespace taken into account by jaeger-query can be configured via a TempoStack CR entry.
To achieve this the Operator will set the jaeger-query--prometheus.query.namespace=
flag.
Since Jaeger version 1.62, jaeger-query usestraces.span.metrics
as default too.Example how to restore the default namespace used prior to version
0.109.0
, by configuring an empty value forredMetricsNamespace
in the TempoStack CR:apiVersion: tempo.grafana.com/v1alpha1 kind: TempoStack ... spec: template: queryFrontend: jaegerQuery: enabled: true monitorTab: enabled: true prometheusEndpoint: "http://myPromInstance:9090" redMetricsNamespace: ""
More details can be found here:
-
tempostack, tempomonolithic
: Add unified timeout configuration. It changes the default to 30s. (#1045)
Addingspec.timeout
CRD option to configure timeout on all components and default it to 30s.
Before Tempo server was defaulting to 3m, gateway to 2m, OpenShift route to 30s (for query), oauth-proxy to 30s (for query).
🚀 New components 🚀
must-gather
: Add must-gather to collect information about the components deployed by the operator in a cluster. (#1033)
💡 Enhancements 💡
-
tempostack
: Expose a way to set a PodSecurityContext on each component (#996) -
tempostack, tempomonolithic
: bump jaeger to v1.62 (#1050) -
tempostack
: Bump jaeger to v1.60 by replacing the tempo-query gRPC storage plugin due to the deprecation in Jaeger 1.58.0 with a gRPC standalone service. (#1025) -
operator
: Kubernetes 1.30 enablement (#1030) -
tempostack, tempomonolithic
: Make re-encrypt route the default TLS termination to allow access outside the cluster. (#1027) -
tempostack, tempomonolithic
: Add tempo-query CRD option to speed up trace search. (#1048)
Following CRD options were added to speed up trace search in Jaeger UI/API. The trace search first
searches for traceids and then it gets a full trace. With this configuration option the requests
to get the full trace can be run in parallel:
ForTempoStack
-spec.template.queryFrontend.jaegerQuery.findTracesConcurrentRequests
ForTempoMonolithic
-spec.jaegerui.findTracesConcurrentRequests
-
tempostack
: bump tempo-query to version with separate tls settings for server and client (#1057)
🧰 Bug fixes 🧰
-
tempostack
: The default value for the IngressType type is now correctly "" (empty string). Previously, it was impossible to select it in tools like the OpenShift web console, what could cause some issues. (#1054) -
tempostack
: Add support for memberlist bind network configuration (#1060)
Adds support to configure the memberlist instance_addr field using the pod network IP range instead of the default private network range used.
In managed Kubernetes/OpenShift cluster environments as well as in special on-prem setup the private IP range might not be available for using them.
With this change set the TempoStack administrator can choose as a bind address the current pod network IP assigned by the cluster's pod network. -
tempostack
: grant jaeer-query access to pki certs (#1051) -
tempostack
: Create query-frontend service monitor with HTTP protocol when gateway is disabled (#1070) -
tempostack
: Fix panic when toggling spec.storage.tls.enabled to true, when using Tempo with AWS STS (#1067) -
tempostack, tempomonolithic
: Mount CA and Certs to tempo-query when tls is enabled. (#1038) -
tempostack, tempomonolithic
: The operator no longer sets the--prometheus.query.support-spanmetrics-connector
flag that got removed in Jaeger 1.58. (#1036)
The Flag controled whether the metrics queries should match the OpenTelemetry Collector's spanmetrics connector naming or spanmetrics processor naming. -
tempostack
: Use the ReadinessProbe to better indicate when tempo-query is ready to accept requests. Improving the startup reliability by avoiding lost data. (#1058)
Without a readiness check in place, there is a risk that data will be lost when the queryfrontend pod is ready but the tempo query API is not yet available.
Components
- Tempo: v2.6.1
Release v0.13.0
🧰 Bug fixes 🧰
operator
: Fix service account for monitoring-view cluster role binding when using oauth proxy. (#1016)tempostack
: Fix setting annotations for Gateway route (#1014)tempostack, tempomonolithic
: Fix infinite reconciliation on OpenShift when route for Jaeger UI is enabled. (#1018)tempostack, tempomonolithic
: Cleanup instance metrics from the operator on instance delete action. (#1019)
Components
- Tempo: v2.5.0
Release v0.12.0
💡 Enhancements 💡
-
tempostack, tempomonolithic
: Add support for AWS S3 STS authentication. (#978)
Now storage secret for S3 can containdata: bucket: # Bucket name region: # A valid AWS region, e.g. us-east-1 role_arn: # The AWS IAM Role associated with a trust relationship to Tempo serviceaccount
-
tempostack
: Use TLS via OpenShift service annotation when gateway/multitenancy is disabled (#963)
On OpenShift when operator configservingCertsService
is enabled and the following TempoStack CR is used.
The operator provisions OpenShift serving certificates for the distributor ingest APIsapiVersion: tempo.grafana.com/v1alpha1 kind: TempoStack spec: template: distributor: tls: enabled: true
No
certName
andcaName
should be provided, If you specify it, those will be used instead.In order to use this on the client side, the openshift CA certificate should be used, there are two ways of get
access to it. You can mount the configmap generated by the operator, which will have the name<tempostack-name>-serving-cabundle
Or you can access to it onvar/run/secrets/kubernetes.io/serviceaccount/service-ca.crt
.An example of OTel configuration used:
exporters: otlp: endpoint: tempo-simplest-distributor.chainsaw-tls-singletenant.svc.cluster.local:4317 tls: insecure: false ca_file: "/var/run/secrets/kubernetes.io/serviceaccount/service-ca.crt"
-
tempomonolithic
: Use TLS via OpenShift service annotation when gateway/multitenancy is disabled (monolithic) (#963)
On OpenShift when operator configservingCertsService
is enabled and the following TempoMonolithic CR is used.
The operator provisions OpenShift serving certificates for the distributor ingest APIsapiVersion: tempo.grafana.com/v1alpha1 kind: TempoMonolithic spec: ingestion: otlp: grpc: tls: enabled: true
or
apiVersion: tempo.grafana.com/v1alpha1 kind: TempoMonolithic spec: ingestion: otlp: http: tls: enabled: true
No
certName
andcaName
should be provided, If you specify it, those will be used instead. -
tempostack, tempomonolithic
: Bump observatorium gateway, (#991)
In this version upstream certs and CA are reloaded if changed
🧰 Bug fixes 🧰
tempostack, tempomonolithic
: Allow configmaps and secrets with dot in the name (as it is valid for those objects to have dots as part of it's name) (#983)tempostack
: Assign correct replicas in gateway component if it is specified in the CR, default is 1 if not set (#993)tempomonolithic
: Allow create a monolithic with tls enabled on both grpc/http (#976)
Components
- Tempo: v2.5.0