From 3b3095826ca64b1f0f9f61ceeda8d32fa91d69e8 Mon Sep 17 00:00:00 2001 From: Jimmy Rimmer Date: Fri, 8 Apr 2022 11:53:24 -0700 Subject: [PATCH 1/3] ENGOPS-2374 Add type; set "interval" to 1 explicitly --- plugins/outputs/datadog/datadog.go | 19 ++++++++++++++++--- 1 file changed, 16 insertions(+), 3 deletions(-) diff --git a/plugins/outputs/datadog/datadog.go b/plugins/outputs/datadog/datadog.go index c97929eaefd05..797f372f79c7d 100644 --- a/plugins/outputs/datadog/datadog.go +++ b/plugins/outputs/datadog/datadog.go @@ -36,7 +36,9 @@ type Metric struct { Metric string `json:"metric"` Points [1]Point `json:"points"` Host string `json:"host"` + Type string `json:"type,omitempty"` Tags []string `json:"tags,omitempty"` + Interval int64 `json:"interval"` } type Point [2]float64 @@ -85,10 +87,21 @@ func (d *Datadog) Write(metrics []telegraf.Metric) error { } else { dname = m.Name() + "." + fieldName } + var tname string + switch m.Type() { + case telegraf.Counter: + tname = "count" + case telegraf.Gauge: + tname = "gauge" + default: + tname = "" + } metric := &Metric{ - Metric: dname, - Tags: metricTags, - Host: host, + Metric: dname, + Tags: metricTags, + Host: host, + Type: tname, + Interval: 1, } metric.Points[0] = dogM tempSeries = append(tempSeries, metric) From 0a69edc9d57fc7644d04b97e4b300798fa7073ad Mon Sep 17 00:00:00 2001 From: Jimmy Rimmer Date: Tue, 12 Apr 2022 16:44:49 -0700 Subject: [PATCH 2/3] [ENGOPS-2374] updated README --- plugins/outputs/datadog/README.md | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/plugins/outputs/datadog/README.md b/plugins/outputs/datadog/README.md index ec20f74cbb6e5..6fad967e95a38 100644 --- a/plugins/outputs/datadog/README.md +++ b/plugins/outputs/datadog/README.md @@ -33,5 +33,11 @@ key with a `.` character. Field values are converted to floating point numbers. Strings and floats that cannot be sent over JSON, namely NaN and Inf, are ignored. +We do not send `Rate` types. Counts are sent as `count`, with an +interval hard-coded to 1. Note that this behavior does *not* play +super-well if running simultaneously with current Datadog agents; they +will attempt to change to `Rate` with `interval=10`. We prefer this +method, however, as it reflects the raw data more accurately. + [metrics]: https://docs.datadoghq.com/api/v1/metrics/#submit-metrics [apikey]: https://app.datadoghq.com/account/settings#api From 4aaea39a06980abb56d430a3d7bf07488bdcbfdb Mon Sep 17 00:00:00 2001 From: Jimmy Rimmer Date: Tue, 12 Apr 2022 17:12:51 -0700 Subject: [PATCH 3/3] [ENGOPS-2374] ran `gofmt` --- plugins/outputs/datadog/datadog.go | 12 ++++++------ 1 file changed, 6 insertions(+), 6 deletions(-) diff --git a/plugins/outputs/datadog/datadog.go b/plugins/outputs/datadog/datadog.go index 797f372f79c7d..682be05070b66 100644 --- a/plugins/outputs/datadog/datadog.go +++ b/plugins/outputs/datadog/datadog.go @@ -33,12 +33,12 @@ type TimeSeries struct { } type Metric struct { - Metric string `json:"metric"` - Points [1]Point `json:"points"` - Host string `json:"host"` - Type string `json:"type,omitempty"` - Tags []string `json:"tags,omitempty"` - Interval int64 `json:"interval"` + Metric string `json:"metric"` + Points [1]Point `json:"points"` + Host string `json:"host"` + Type string `json:"type,omitempty"` + Tags []string `json:"tags,omitempty"` + Interval int64 `json:"interval"` } type Point [2]float64