DEV Community

Lucien Boix
Lucien Boix

Posted on • Edited on

Datadog : how to filter metrics on tag "team"

We created a Datadog dashboard to monitor, across our organization, basic metrics about the health of our apps : logs in errors by service, Kubernetes containers restarts, APM errors by service, etc.

A few weeks ago, I wanted to add a "Team" filter on it : the goal was to help our different teams using it during their "morning routine" (a daily check of their applications metrics).

It appeared more challenging than I thought but with the help of Datadog Support we managed to figure it out. I am sharing this knowledge here in case that can help you achieve the same goal.

Introduction

Basically the most important link is this one, listing all available metrics in your Datadog account :

If in the "Tags" section of your metric (the one you want to use in your dashboard) you do not see the one you want to filter on (in our case "team"), then it means it has not been propagated correctly.

We discovered with Datadog Support that the tagging is different given the nature of the metric you want to use in your dashboard.

Here are the 3 usecases we identified, but first let's do some preparation if you plan to filter your metrics on teams.

Preparation

spec:
template:
metadata:
labels:
team: your-team-name


## Logs metric

Make sure your Datadog agent does have this environment variable in its configuration : it will map the label "team" of your pods with the tag "team" of metrics collected from it.

Enter fullscreen mode Exit fullscreen mode
  • name: DD_KUBERNETES_POD_LABELS_AS_TAGS value: '{"team":"team"}'

> Important : if you do use a **custom** logs metric in your dashboard (that means this one is defined [here](https://app.datadoghq.com/logs/pipelines/generate-metrics), then edit it and make sure to add the "team" tag in the "Group By" section like this :
> ![Image description](https://dev-to-uploads.s3.amazonaws.com/uploads/articles/4gkjjq4v868gc5qarqxw.png)
> Clic on "Update Metric"

Wait and see if it populates correctly in : 
- https://app.datadoghq.com/logs (clic on one recent log to see its details)
- https://app.datadoghq.com/metric/summary

## Kubernetes metric

If you want to filter your `kubernetes_state.container.*` metrics for example, make sure to have this option activated for your Datadog **Cluster** agent configuration.

If you set up it through [Helm](https://github.com/DataDog/helm-charts/blob/bc09ff3950999aeea1ee142e055b6be452902feb/charts/datadog/values.yaml#L194) :

Enter fullscreen mode Exit fullscreen mode

datadog:
kubeStateMetricsCore:
labelsAsTags:
pod:
team: team


If you set up it manually through a YAML manifest, make sure to update this [ConfigMap](https://github.com/DataDog/datadog-agent/blob/main/Dockerfiles/manifests/kubernetes_state_core/cluster-agent-confd-configmap.yaml#L38) :

Enter fullscreen mode Exit fullscreen mode

labels_as_tags:
pod:
team: team


Wait and see if it populates correctly in :
- https://app.datadoghq.com/metric/summary

## APM metric

If you want to filter on `trace.servlet.request.errors.by_http_status` for example, you will need to add this environment variable to your Datadog agent configuration :

Enter fullscreen mode Exit fullscreen mode
  • name: DD_APM_FEATURES value: 'enable_cid_stats'

Then go [here](https://app.datadoghq.com/apm/settings) and "Aggregate APM metrics" by "team" like this :

![Image description](https://dev-to-uploads.s3.amazonaws.com/uploads/articles/xwqftztjkkby2uf7r5b0.png)

Wait and see if it populates correctly in :
- https://app.datadoghq.com/metric/summary

## Plugging team filter to your dashboard
Finally it's time to use this new tag you populated!
On the upper right of your dashboard, clic on the **+** ("Add Variable") and specify it like this :

![Image description](https://dev-to-uploads.s3.amazonaws.com/uploads/articles/pb2a8eefeglyset3yl5q.png)

Then edit all the sections to add it to the scope of the metric displayed in each one of them, and Save, like this :

![Image description](https://dev-to-uploads.s3.amazonaws.com/uploads/articles/mrx8g736r0xcundfe3c7.png)

Hope it helped, have a great day and happy monitoring!

## Sources
- https://docs.datadoghq.com/containers/kubernetes/tag/?tab=manualdaemonset#pod-labels-as-tags
- https://docs.datadoghq.com/tracing/guide/setting_primary_tags_to_scope/?tab=kuberneteswithouthelm#container-based-second-primary-tags

Enter fullscreen mode Exit fullscreen mode

Top comments (0)