Skip to content

Latest commit

 

History

History
 
 

observability

Folders and files

NameName
Last commit message
Last commit date

parent directory

..
 
 
 
 
 
 
 
 

Sending Traces and Metrics to the OpenTelemetry Collector

In this example, we will show you an example configuration for enabling the operator to send OpenTelemetry traces and metrics to the OpenTelemetry Collector. The Collector will then be used to forward the gathered data to Jaeger and Prometheus. The application deployed uses an example of pre-Deployment Evaluation based on prometheus metrics.

TL;DR

  • You can install the whole demo including Keptn-lifecycle-toolkit using: make install
  • Deploy the PodTatoHead Demo Application: make deploy-podtatohead
  • Afterward, see it in action as defined here: OpenTelemetry in Action

Prerequisites

This tutorial assumes, that you already installed the Keptn Lifecycle Controller ( see https://github.com/keptn/lifecycle-toolkit). The installation instructions can be found here. As well, you have both Jaeger and the Prometheus Operator installed in your Cluster. Also, please ensure that the Prometheus Operator has the required permissions to watch resources of the keptn-lifecycle-toolkit-system namespace ( see https://prometheus-operator.dev/docs/kube/monitoring-other-namespaces/ as a reference). For setting up both Jaeger and Prometheus, please refer to their docs:

If you don't have an already existing installation of Jaeger manifest or Prometheus, you can run these commands to have a basic installation up and running.

# Install Jaeger into the observability namespace and the Jaeger resource into the lifecycle-toolkit namespace
kubectl create namespace observability
kubectl apply -f https://github.com/jaegertracing/jaeger-operator/releases/download/v1.38.0/jaeger-operator.yaml -n observability
kubectl apply -f config/jaeger.yaml -n keptn-lifecycle-toolkit-system

# Install Prometheus
kubectl create namespace monitoring
kubectl apply --server-side -f config/prometheus/setup
kubectl apply -f config/prometheus/

With these commands, the Jaeger and Prometheus Operator will be installed in the observability and monitoring namespaces, respectively.

Configuring the OpenTelemetry Collector and Prometheus ServiceMonitor

Once Jaeger and Prometheus are installed, you can deploy and configure the OpenTelemetry collector using the manifests in the config directory:

kubectl apply -f config/otel-collector.yaml -n keptn-lifecycle-toolkit-system

Also, please ensure that the OTEL_COLLECTOR_URL env vars of both the lifecycle-operator, as well as the keptn-scheduler deployments are set appropriately. By default, they are set to otel-collector:4317, which should be the correct value for this tutorial.

Eventually, there should be a pod for the otel-collector deployment up and running:

$ kubectl get pods -lapp=opentelemetry -n keptn-lifecycle-toolkit-system

NAME                              READY   STATUS    RESTARTS      AGE
otel-collector-6fc4cc84d6-7hnvp   1/1     Running   0             92m

If you want to extend the OTel Collector configuration to send your telemetry data to other Observability platform, you can edit the Collector ConfigMap with the following command:

kubectl edit configmap otel-collector-conf -n keptn-lifecycle-toolkit-system

When the otel-collector pod is up and running, restart the keptn-scheduler and lifecycle-operator so they can pick up the new configuration.

kubectl rollout restart deployment -n keptn-lifecycle-toolkit-system keptn-scheduler lifecycle-operator

Seeing the OpenTelemetry Collector in action

After everything has been set up, use the lifecycle operator to deploy a workload (e.g. using the single-service or podtato-head example in the examples folder). To showcase pre-Evaluation checks we created a new version of podtato-head app in assets/podtetohead-deployment-evaluation. You can run make deploy-podtatohead to check pre-Evaluations of prometheus metrics both at app and workload instance level. Once an example has been deployed, you can view the generated traces in Jaeger. To do so, please create a port-forward for the jaeger-query service:

kubectl port-forward -n keptn-lifecycle-toolkit-system svc/jaeger-query 16686 

Afterwards, you can view the Jaeger UI in the browser at localhost:16686. There you should see the traces generated by the lifecycle controller, which should look like this:

Traces overview

Screenshot of the traces overview in Jaeger

Trace details

Screenshot of a trace in Jaeger

In Prometheus, do a port forward to the prometheus service inside your cluster (the exact name and namespace of the prometheus service will depend on your Prometheus setup - we are using the defaults that come with the example of the Prometheus Operator tutorial).

kubectl -n monitoring port-forward svc/prometheus-k8s 9090

Afterwards, you can view the Prometheus UI in the browser at localhost:9090. There, in the Targets section, you should see an entry for the otel-collector:

Screenshot of a target in Prometheus

Also, in the Graph section, you can retrieve metrics reported by the Keptn Lifecycle Controller (all of the available metrics start with the keptn prefix):

Screenshot of the auto-complete menu in a Prometheus query

To view the exported metrics in Grafana, we have provided dashboards which have been automatically installed with this example. To display them, please first create a port-forward for the grafana service in the monitoring namespace:

make port-forward-grafana

Now, you should be able to see it in the Grafana UI under Dashboards > General.

Screenshot of a dashboard in Grafana