From 1d4beab7a4558a34a433d4ac2eae1e548ff10abc Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E2=98=83=20pitr?= Date: Sat, 24 Jul 2021 21:38:56 +0200 Subject: [PATCH 1/3] fixes for ZMON client MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Changes: - only add group_by "key" if key is provided - remove deprecated aggregators "dev" and "first" - add X-Attribution header for query attribution Signed-off-by: ☃ pitr --- pkg/zmon/zmon.go | 22 +++++++++------------- 1 file changed, 9 insertions(+), 13 deletions(-) diff --git a/pkg/zmon/zmon.go b/pkg/zmon/zmon.go index 1501e16e..6942d21b 100644 --- a/pkg/zmon/zmon.go +++ b/pkg/zmon/zmon.go @@ -15,9 +15,7 @@ var ( // https://kairosdb.github.io/docs/build/html/restapi/Aggregators.html validAggregators = map[string]struct{}{ "avg": struct{}{}, - "dev": struct{}{}, "count": struct{}{}, - "first": struct{}{}, "last": struct{}{}, "max": struct{}{}, "min": struct{}{}, @@ -112,17 +110,10 @@ func (c *Client) Query(checkID int, key string, tags map[string]string, aggregat StartRelative: durationToSampling(duration), Metrics: []metric{ { - Name: fmt.Sprintf("zmon.check.%d", checkID), - Limit: 10000, // maximum limit of ZMON - Tags: tagsSlice, - GroupBy: []tagGroup{ - { - Name: "tag", - Tags: []string{ - "key", - }, - }, - }, + Name: fmt.Sprintf("zmon.check.%d", checkID), + Limit: 10000, // maximum limit of ZMON + Tags: tagsSlice, + GroupBy: []tagGroup{}, Aggregators: make([]aggregator, 0, len(aggregators)), }, }, @@ -142,6 +133,10 @@ func (c *Client) Query(checkID int, key string, tags map[string]string, aggregat // add key to query if defined if key != "" { query.Metrics[0].Tags["key"] = []string{key} + query.Metrics[0].GroupBy = append(query.Metrics[0].GroupBy, tagGroup{ + Name: "tag", + Tags: []string{"key"}, + }) } body, err := json.Marshal(&query) @@ -158,6 +153,7 @@ func (c *Client) Query(checkID int, key string, tags map[string]string, aggregat req.Header.Set("Content-Type", "application/json") req.Header.Set("Accept", "application/json") + req.Header.Set("X-Attribution", fmt.Sprintf("kube-metrics-adapter/%d", checkID)) resp, err := c.http.Do(req) if err != nil { From c626f414dbffe6cb90b32ffeb32de79b7f156ca6 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E2=98=83=20pitr?= Date: Mon, 26 Jul 2021 11:14:27 +0200 Subject: [PATCH 2/3] remove deprecated zmon aggregators in README MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Signed-off-by: ☃ pitr --- README.md | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/README.md b/README.md index a918dfd1..ff6b6f03 100644 --- a/README.md +++ b/README.md @@ -587,8 +587,8 @@ For instance if you define the entity filter then you might want to get an average over the metrics for those three entities. This would be possible by using the `avg` aggregator. The default aggregator is `last` which returns only the latest metric point from the -query. The supported aggregation functions are `avg`, `dev`, `count`, -`first`, `last`, `max`, `min`, `sum`, `diff`. See the [KariosDB docs](https://kairosdb.github.io/docs/build/html/restapi/Aggregators.html) for +query. The supported aggregation functions are `avg`, `count`, +`last`, `max`, `min`, `sum`, `diff`. See the [KariosDB docs](https://kairosdb.github.io/docs/build/html/restapi/Aggregators.html) for details. The `duration` defines the duration used for the timeseries query. E.g. if you From 582c94255ff6f95ac2254acb16d1c6636e6525ff Mon Sep 17 00:00:00 2001 From: Jonathan Juares Beber Date: Mon, 26 Jul 2021 15:31:10 +0200 Subject: [PATCH 3/3] Add test for ZMON Key This commit add tests to the ZMON package when handling the key used on the metrics query. Signed-off-by: Jonathan Juares Beber --- pkg/zmon/zmon_test.go | 32 ++++++++++++++++++++++++++++++++ 1 file changed, 32 insertions(+) diff --git a/pkg/zmon/zmon_test.go b/pkg/zmon/zmon_test.go index f3193b2a..938bfe04 100644 --- a/pkg/zmon/zmon_test.go +++ b/pkg/zmon/zmon_test.go @@ -1,6 +1,7 @@ package zmon import ( + "encoding/json" "fmt" "net/http" "net/http/httptest" @@ -130,6 +131,37 @@ func TestQuery(tt *testing.T) { tt.Run(ti.msg, func(t *testing.T) { ts := httptest.NewServer(http.HandlerFunc( func(w http.ResponseWriter, r *http.Request) { + if ti.status == http.StatusOK { + q := metricQuery{} + decoder := json.NewDecoder(r.Body) + err := decoder.Decode(&q) + assert.NoError(t, err) + + numberOfMetrics := len(q.Metrics) + assert.Equal(t, 1, numberOfMetrics, "expected 1 metrics, got %d", numberOfMetrics) + metric := q.Metrics[0] + if ti.key != "" { + numberOfTags := len(metric.Tags) + assert.Equal(t, 1, numberOfTags, "expected 1 metric, got %d", numberOfTags) + tag := metric.Tags["key"][0] + assert.Equal(t, ti.key, tag, "expected key '%s' as tag, got '%s'", ti.key, tag) + + numberOfTagGroups := len(metric.GroupBy) + assert.Equal(t, 1, numberOfTagGroups, "expected 1 GroupBy tag, got %d", numberOfTagGroups) + tagGroups := metric.GroupBy[0] + + numberOfTagGroupTags := len(tagGroups.Tags) + assert.Equal(t, 1, numberOfTagGroupTags, "expected 1 GroupBy tag, got %d", numberOfTagGroupTags) + + expectedGroupByTag := "key" + groupByTag := tagGroups.Tags[0] + assert.Equal(t, expectedGroupByTag, groupByTag, "expected GroupBy tag '%s', got '%s'", expectedGroupByTag, groupByTag) + } else { + _, ok := metric.Tags["key"] + assert.Equal(t, false, ok) + assert.Equal(t, 0, len(metric.GroupBy)) + } + } w.WriteHeader(ti.status) _, err := w.Write([]byte(ti.body)) assert.NoError(t, err)