From 8686c7d8364e618566fb52955435ade002c08073 Mon Sep 17 00:00:00 2001 From: shaan420 Date: Fri, 27 Oct 2023 21:39:46 +0530 Subject: [PATCH] redact host and instance tags for internal metrics (#237) * redact host and instance tags for internal metrics * fix unit test --- m3/reporter.go | 6 +++++- m3/reporter_test.go | 7 +++++-- 2 files changed, 10 insertions(+), 3 deletions(-) diff --git a/m3/reporter.go b/m3/reporter.go index c930d5c2..8b4f8f8f 100644 --- a/m3/reporter.go +++ b/m3/reporter.go @@ -66,6 +66,8 @@ const ( DefaultHistogramBucketIDName = "bucketid" // DefaultHistogramBucketName is the default histogram bucket name tag name DefaultHistogramBucketName = "bucket" + // DefaultTagRedactValue is the default tag value to use when redacting + DefaultTagRedactValue = "global" // DefaultHistogramBucketTagPrecision is the default // precision to use when formatting the metric tag // with the histogram bucket bound values. @@ -287,7 +289,9 @@ func NewReporter(opts Options) (Reporter, error) { } internalTags := map[string]string{ - "version": tally.Version, + "version": tally.Version, + "host": DefaultTagRedactValue, + "instance": DefaultTagRedactValue, } for k, v := range opts.InternalTags { diff --git a/m3/reporter_test.go b/m3/reporter_test.go index 6e5bbb0a..308debad 100644 --- a/m3/reporter_test.go +++ b/m3/reporter_test.go @@ -599,15 +599,18 @@ func TestReporterCommmonTagsInternal(t *testing.T) { for k, v := range internalTags { require.True(t, tagEquals(metric.Tags, k, v)) } + + // The following tags should be redacted. + require.True(t, tagEquals(metric.Tags, "host", DefaultTagRedactValue)) + require.True(t, tagEquals(metric.Tags, "instance", DefaultTagRedactValue)) } else { require.Equal(t, "testCounter1", metric.Name) require.False(t, tagIncluded(metric.Tags, "internal1")) require.False(t, tagIncluded(metric.Tags, "internal2")) } + // The following tags should not be present as part of the individual metrics // as they are common tags. - require.False(t, tagIncluded(metric.Tags, "host")) - require.False(t, tagIncluded(metric.Tags, "instance")) require.False(t, tagIncluded(metric.Tags, "service")) } require.Equal(t, internalMetrics, numInternalMetricsActual)