From f6adcea2077c2c978de718b9f50ab45074cf8866 Mon Sep 17 00:00:00 2001 From: Charles Korn Date: Tue, 8 Oct 2024 13:00:13 +1100 Subject: [PATCH 1/3] Fix the issue where `rate` or `increase` can return multiple series with the same labels --- .../functions/rate_increase.go | 2 + .../testdata/ours/functions.test | 106 ++++++++++++++++++ 2 files changed, 108 insertions(+) diff --git a/pkg/streamingpromql/functions/rate_increase.go b/pkg/streamingpromql/functions/rate_increase.go index 13465c62a45..d5f8b26426f 100644 --- a/pkg/streamingpromql/functions/rate_increase.go +++ b/pkg/streamingpromql/functions/rate_increase.go @@ -20,6 +20,7 @@ var Rate = FunctionOverRangeVector{ SeriesValidationFuncFactory: rateSeriesValidator, SeriesMetadataFunc: DropSeriesName, NeedsSeriesNamesForAnnotations: true, + NeedsSeriesDeduplication: true, } var Increase = FunctionOverRangeVector{ @@ -27,6 +28,7 @@ var Increase = FunctionOverRangeVector{ SeriesValidationFuncFactory: rateSeriesValidator, SeriesMetadataFunc: DropSeriesName, NeedsSeriesNamesForAnnotations: true, + NeedsSeriesDeduplication: true, } // isRate is true for `rate` function, or false for `instant` function diff --git a/pkg/streamingpromql/testdata/ours/functions.test b/pkg/streamingpromql/testdata/ours/functions.test index ac6f3ba248b..995c19c3b3e 100644 --- a/pkg/streamingpromql/testdata/ours/functions.test +++ b/pkg/streamingpromql/testdata/ours/functions.test @@ -298,3 +298,109 @@ eval_fail instant at 15m label_replace(rate({env="1"}[10m]), "__name__", "rate_$ # rate_another_metric{env="1"} 0.2 clear + +# Test the case where multiple series have the same labels after the metric name is removed by a function. +load 1m + float_metric_1 0+1x4 + float_metric_2 0+2x4 + histogram_metric_1 {{sum:0 count:0}}x4 + histogram_metric_2 {{sum:1 count:1}}x4 + +eval_fail instant at 5m abs({__name__=~"float_metric_.*"}) + expected_fail_message vector cannot contain metrics with the same labelset + +eval_fail instant at 5m acos({__name__=~"float_metric_.*"}) + expected_fail_message vector cannot contain metrics with the same labelset + +eval_fail instant at 5m acosh({__name__=~"float_metric_.*"}) + expected_fail_message vector cannot contain metrics with the same labelset + +eval_fail instant at 5m asin({__name__=~"float_metric_.*"}) + expected_fail_message vector cannot contain metrics with the same labelset + +eval_fail instant at 5m asinh({__name__=~"float_metric_.*"}) + expected_fail_message vector cannot contain metrics with the same labelset + +eval_fail instant at 5m atan({__name__=~"float_metric_.*"}) + expected_fail_message vector cannot contain metrics with the same labelset + +eval_fail instant at 5m atanh({__name__=~"float_metric_.*"}) + expected_fail_message vector cannot contain metrics with the same labelset + +eval_fail instant at 5m avg_over_time({__name__=~"float_metric_.*"}[5m]) + expected_fail_message vector cannot contain metrics with the same labelset + +eval_fail instant at 5m ceil({__name__=~"float_metric_.*"}) + expected_fail_message vector cannot contain metrics with the same labelset + +eval_fail instant at 5m cos({__name__=~"float_metric_.*"}) + expected_fail_message vector cannot contain metrics with the same labelset + +eval_fail instant at 5m cosh({__name__=~"float_metric_.*"}) + expected_fail_message vector cannot contain metrics with the same labelset + +eval_fail instant at 5m count_over_time({__name__=~"float_metric_.*"}[5m]) + expected_fail_message vector cannot contain metrics with the same labelset + +eval_fail instant at 5m deg({__name__=~"float_metric_.*"}) + expected_fail_message vector cannot contain metrics with the same labelset + +eval_fail instant at 5m exp({__name__=~"float_metric_.*"}) + expected_fail_message vector cannot contain metrics with the same labelset + +eval_fail instant at 5m floor({__name__=~"float_metric_.*"}) + expected_fail_message vector cannot contain metrics with the same labelset + +eval_fail instant at 5m histogram_count({__name__=~"histogram_metric_.*"}) + expected_fail_message vector cannot contain metrics with the same labelset + +eval_fail instant at 5m histogram_sum({__name__=~"histogram_metric_.*"}) + expected_fail_message vector cannot contain metrics with the same labelset + +eval_fail instant at 5m increase({__name__=~"float_metric_.*"}[5m]) + expected_fail_message vector cannot contain metrics with the same labelset + +eval_fail instant at 5m max_over_time({__name__=~"float_metric_.*"}[5m]) + expected_fail_message vector cannot contain metrics with the same labelset + +eval_fail instant at 5m min_over_time({__name__=~"float_metric_.*"}[5m]) + expected_fail_message vector cannot contain metrics with the same labelset + +eval_fail instant at 5m ln({__name__=~"float_metric_.*"}) + expected_fail_message vector cannot contain metrics with the same labelset + +eval_fail instant at 5m log10({__name__=~"float_metric_.*"}) + expected_fail_message vector cannot contain metrics with the same labelset + +eval_fail instant at 5m log2({__name__=~"float_metric_.*"}) + expected_fail_message vector cannot contain metrics with the same labelset + +eval_fail instant at 5m present_over_time({__name__=~"float_metric_.*"}[5m]) + expected_fail_message vector cannot contain metrics with the same labelset + +eval_fail instant at 5m rad({__name__=~"float_metric_.*"}) + expected_fail_message vector cannot contain metrics with the same labelset + +eval_fail instant at 5m rate({__name__=~"float_metric_.*"}[5m]) + expected_fail_message vector cannot contain metrics with the same labelset + +eval_fail instant at 5m sgn({__name__=~"float_metric_.*"}) + expected_fail_message vector cannot contain metrics with the same labelset + +eval_fail instant at 5m sin({__name__=~"float_metric_.*"}) + expected_fail_message vector cannot contain metrics with the same labelset + +eval_fail instant at 5m sinh({__name__=~"float_metric_.*"}) + expected_fail_message vector cannot contain metrics with the same labelset + +eval_fail instant at 5m sqrt({__name__=~"float_metric_.*"}) + expected_fail_message vector cannot contain metrics with the same labelset + +eval_fail instant at 5m sum_over_time({__name__=~"float_metric_.*"}[5m]) + expected_fail_message vector cannot contain metrics with the same labelset + +eval_fail instant at 5m tan({__name__=~"float_metric_.*"}) + expected_fail_message vector cannot contain metrics with the same labelset + +eval_fail instant at 5m tanh({__name__=~"float_metric_.*"}) + expected_fail_message vector cannot contain metrics with the same labelset From 34ee17893c1996f7dfe301bdfe87e1de3e1877d6 Mon Sep 17 00:00:00 2001 From: Charles Korn Date: Tue, 8 Oct 2024 13:06:44 +1100 Subject: [PATCH 2/3] Add changelog entry --- CHANGELOG.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 9f9e3ca55f7..7529d69acc9 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -14,7 +14,7 @@ * `cortex_alertmanager_alerts` * `cortex_alertmanager_silences` * [CHANGE] Cache: Deprecate experimental support for Redis as a cache backend. #9453 -* [FEATURE] Querier: add experimental streaming PromQL engine, enabled with `-querier.query-engine=mimir`. #9367 #9368 #9398 #9399 #9403 #9417 #9418 #9419 #9420 #9482 #9504 #9505 #9507 #9518 #9531 #9532 #9533 +* [FEATURE] Querier: add experimental streaming PromQL engine, enabled with `-querier.query-engine=mimir`. #9367 #9368 #9398 #9399 #9403 #9417 #9418 #9419 #9420 #9482 #9504 #9505 #9507 #9518 #9531 #9532 #9533 #9553 * [FEATURE] Query-frontend: added experimental configuration options `query-frontend.cache-errors` and `query-frontend.results-cache-ttl-for-errors` to allow non-transient responses to be cached. When set to `true` error responses from hitting limits or bad data are cached for a short TTL. #9028 * [FEATURE] gRPC: Support S2 compression. #9322 * `-alertmanager.alertmanager-client.grpc-compression=s2` From e6866f5072351944c7835c1cbaf0313af2460b6f Mon Sep 17 00:00:00 2001 From: Charles Korn Date: Tue, 8 Oct 2024 13:21:22 +1100 Subject: [PATCH 3/3] Disable unsupported upstream test case --- .../testdata/upstream/name_label_dropping.test | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/pkg/streamingpromql/testdata/upstream/name_label_dropping.test b/pkg/streamingpromql/testdata/upstream/name_label_dropping.test index 64805de3458..8dd2b86f045 100644 --- a/pkg/streamingpromql/testdata/upstream/name_label_dropping.test +++ b/pkg/streamingpromql/testdata/upstream/name_label_dropping.test @@ -84,8 +84,9 @@ eval instant at 15m sum by (__name__, env) (metric{env="1"}) # Aggregation operators aggregate metrics with same labelset and to-be-dropped names # This is an accidental side effect of delayed __name__ label dropping -eval instant at 15m sum(rate({env="1"}[10m])) by (env) - {env="1"} 0.4 +# Unsupported by streaming engine. +# eval instant at 15m sum(rate({env="1"}[10m])) by (env) +# {env="1"} 0.4 # Aggregationk operators propagate __name__ label dropping information # Unsupported by streaming engine.