Tempo HA docs - How to enable service graphs

In Grafana Tempo, a service graph is a visual representation of the interrelationships between various services. Service graphs help you to understand the structure of a distributed system, and the connections and dependencies between its components.

See more: Service graphs

Service graphs are generated in charmed tempo HA and pushed to a metrics storage (charmed prometheus or charmed mimir HA). Then, they can be represented in charmed grafana as a graph. So, you need the following integrations to fully use service graphs:

  • send-remote-write
  • grafana-source
  • receive-datasource

Deploy Tempo HA

Check this guide to deploy Tempo HA.

If you intend to deploy charmed Tempo HA in its distributed mode, make sure to deploy a dedicated worker with a metrics-generator role using the config option role-metrics-generator=true.

By default, deploying charmed Tempo HA in its monolithic mode with role all, will have metrics-generator enabled.

Integrate over send-remote-write

The way service graphs work is that the metrics-generator, a Tempo component that derives metrics from ingested traces, processes traces and generates service graphs in the form of Prometheus metrics and pushes them to prometheus/mimir remote write endpoints.

We’ll be using charmed prometheus as the metrics backend, but charmed mimir HA can be used interchangeably as well.

juju deploy prometheus-k8s prometheus --channel edge --trust
juju integrate tempo:send-remote-write prometheus

Integrate over grafana-source

For service graphs to be represented in Grafana, we need to configure tempo and prometheus as datasources in the same grafana instance.

juju deploy grafana-k8s grafana --channel=edge --trust 
juju integrate tempo:grafana-source grafana
juju integrate prometheus:grafana-source grafana

Integrate over receive-datasource

What is left is to configure Tempo’s datasource to link to Prometheus’s datasource and that can be achieved by exchanging datasource UIDs using the grafana_datasource_exchange interface.

juju integrate tempo:receive-datasource prometheus:send-datasource

View service graphs in Grafana

Open Grafana web UI from your local web browser and login using the admin password.

Then, Toggle Menu → Explore → Choose your Tempo datasource → Service Graph → Run query

This should result in a graph similar to the one below: image

Service graphs work by inspecting traces and looking for spans with parent-children relationship that represent a request. So, the nodes and edges that would come up in the graph depend on the workload traces generated by your charmed applications.

Nodes → represent the charmed applications emitting workload spans.

Edges → represent a workload request flow from charmed application A to charmed application B given that their workloads generate spans using the same tracing protocol (e.g: OpenTelemetry protocol).