mirror of
https://github.com/VictoriaMetrics/VictoriaMetrics.git
synced 2025-01-20 07:19:17 +01:00
app/vmselect/promql: add count_eq_over_time(m[d], N)
and count_ne_over_time(m[d], N)
for calculating the number of samples in m
over d
that are equal / not equal to N
This commit is contained in:
parent
1430bbcf33
commit
d242c2f2bd
@ -4145,6 +4145,28 @@ func TestExecSuccess(t *testing.T) {
|
|||||||
resultExpected := []netstorage.Result{r}
|
resultExpected := []netstorage.Result{r}
|
||||||
f(q, resultExpected)
|
f(q, resultExpected)
|
||||||
})
|
})
|
||||||
|
t.Run(`count_eq_over_time`, func(t *testing.T) {
|
||||||
|
t.Parallel()
|
||||||
|
q := `count_eq_over_time(round(5*rand(0))[200s:10s], 1)`
|
||||||
|
r := netstorage.Result{
|
||||||
|
MetricName: metricNameExpected,
|
||||||
|
Values: []float64{2, 4, 5, 2, 6, 6},
|
||||||
|
Timestamps: timestampsExpected,
|
||||||
|
}
|
||||||
|
resultExpected := []netstorage.Result{r}
|
||||||
|
f(q, resultExpected)
|
||||||
|
})
|
||||||
|
t.Run(`count_ne_over_time`, func(t *testing.T) {
|
||||||
|
t.Parallel()
|
||||||
|
q := `count_ne_over_time(round(5*rand(0))[200s:10s], 1)`
|
||||||
|
r := netstorage.Result{
|
||||||
|
MetricName: metricNameExpected,
|
||||||
|
Values: []float64{18, 16, 15, 18, 14, 14},
|
||||||
|
Timestamps: timestampsExpected,
|
||||||
|
}
|
||||||
|
resultExpected := []netstorage.Result{r}
|
||||||
|
f(q, resultExpected)
|
||||||
|
})
|
||||||
t.Run(`increases_over_time`, func(t *testing.T) {
|
t.Run(`increases_over_time`, func(t *testing.T) {
|
||||||
t.Parallel()
|
t.Parallel()
|
||||||
q := `increases_over_time(rand(0)[200s:10s])`
|
q := `increases_over_time(rand(0)[200s:10s])`
|
||||||
@ -6251,6 +6273,8 @@ func TestExecError(t *testing.T) {
|
|||||||
f(`share_gt_over_time()`)
|
f(`share_gt_over_time()`)
|
||||||
f(`count_le_over_time()`)
|
f(`count_le_over_time()`)
|
||||||
f(`count_gt_over_time()`)
|
f(`count_gt_over_time()`)
|
||||||
|
f(`count_eq_over_time()`)
|
||||||
|
f(`count_ne_over_time()`)
|
||||||
|
|
||||||
// Invalid argument type
|
// Invalid argument type
|
||||||
f(`median_over_time({}, 2)`)
|
f(`median_over_time({}, 2)`)
|
||||||
|
@ -64,6 +64,8 @@ var rollupFuncs = map[string]newRollupFunc{
|
|||||||
"share_gt_over_time": newRollupShareGT,
|
"share_gt_over_time": newRollupShareGT,
|
||||||
"count_le_over_time": newRollupCountLE,
|
"count_le_over_time": newRollupCountLE,
|
||||||
"count_gt_over_time": newRollupCountGT,
|
"count_gt_over_time": newRollupCountGT,
|
||||||
|
"count_eq_over_time": newRollupCountEQ,
|
||||||
|
"count_ne_over_time": newRollupCountNE,
|
||||||
"histogram_over_time": newRollupFuncOneArg(rollupHistogram),
|
"histogram_over_time": newRollupFuncOneArg(rollupHistogram),
|
||||||
"rollup": newRollupFuncOneArg(rollupFake),
|
"rollup": newRollupFuncOneArg(rollupFake),
|
||||||
"rollup_rate": newRollupFuncOneArg(rollupFake), // + rollupFuncsRemoveCounterResets
|
"rollup_rate": newRollupFuncOneArg(rollupFake), // + rollupFuncsRemoveCounterResets
|
||||||
@ -895,6 +897,26 @@ func countFilterGT(values []float64, gt float64) int {
|
|||||||
return n
|
return n
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func countFilterEQ(values []float64, eq float64) int {
|
||||||
|
n := 0
|
||||||
|
for _, v := range values {
|
||||||
|
if v == eq {
|
||||||
|
n++
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return n
|
||||||
|
}
|
||||||
|
|
||||||
|
func countFilterNE(values []float64, ne float64) int {
|
||||||
|
n := 0
|
||||||
|
for _, v := range values {
|
||||||
|
if v != ne {
|
||||||
|
n++
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return n
|
||||||
|
}
|
||||||
|
|
||||||
func newRollupShareFilter(args []interface{}, countFilter func(values []float64, limit float64) int) (rollupFunc, error) {
|
func newRollupShareFilter(args []interface{}, countFilter func(values []float64, limit float64) int) (rollupFunc, error) {
|
||||||
rf, err := newRollupCountFilter(args, countFilter)
|
rf, err := newRollupCountFilter(args, countFilter)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
@ -914,6 +936,14 @@ func newRollupCountGT(args []interface{}) (rollupFunc, error) {
|
|||||||
return newRollupCountFilter(args, countFilterGT)
|
return newRollupCountFilter(args, countFilterGT)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func newRollupCountEQ(args []interface{}) (rollupFunc, error) {
|
||||||
|
return newRollupCountFilter(args, countFilterEQ)
|
||||||
|
}
|
||||||
|
|
||||||
|
func newRollupCountNE(args []interface{}) (rollupFunc, error) {
|
||||||
|
return newRollupCountFilter(args, countFilterNE)
|
||||||
|
}
|
||||||
|
|
||||||
func newRollupCountFilter(args []interface{}, countFilter func(values []float64, limit float64) int) (rollupFunc, error) {
|
func newRollupCountFilter(args []interface{}, countFilter func(values []float64, limit float64) int) (rollupFunc, error) {
|
||||||
if err := expectRollupArgsNum(args, 2); err != nil {
|
if err := expectRollupArgsNum(args, 2); err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
|
@ -285,6 +285,44 @@ func TestRollupCountGTOverTime(t *testing.T) {
|
|||||||
f(1000, 0)
|
f(1000, 0)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func TestRollupCountEQOverTime(t *testing.T) {
|
||||||
|
f := func(eq, vExpected float64) {
|
||||||
|
t.Helper()
|
||||||
|
eqs := []*timeseries{{
|
||||||
|
Values: []float64{eq},
|
||||||
|
Timestamps: []int64{123},
|
||||||
|
}}
|
||||||
|
var me metricsql.MetricExpr
|
||||||
|
args := []interface{}{&metricsql.RollupExpr{Expr: &me}, eqs}
|
||||||
|
testRollupFunc(t, "count_eq_over_time", args, &me, vExpected)
|
||||||
|
}
|
||||||
|
|
||||||
|
f(-123, 0)
|
||||||
|
f(0, 0)
|
||||||
|
f(34, 4)
|
||||||
|
f(123, 1)
|
||||||
|
f(12, 1)
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestRollupCountNEOverTime(t *testing.T) {
|
||||||
|
f := func(ne, vExpected float64) {
|
||||||
|
t.Helper()
|
||||||
|
nes := []*timeseries{{
|
||||||
|
Values: []float64{ne},
|
||||||
|
Timestamps: []int64{123},
|
||||||
|
}}
|
||||||
|
var me metricsql.MetricExpr
|
||||||
|
args := []interface{}{&metricsql.RollupExpr{Expr: &me}, nes}
|
||||||
|
testRollupFunc(t, "count_ne_over_time", args, &me, vExpected)
|
||||||
|
}
|
||||||
|
|
||||||
|
f(-123, 12)
|
||||||
|
f(0, 12)
|
||||||
|
f(34, 8)
|
||||||
|
f(123, 11)
|
||||||
|
f(12, 11)
|
||||||
|
}
|
||||||
|
|
||||||
func TestRollupQuantileOverTime(t *testing.T) {
|
func TestRollupQuantileOverTime(t *testing.T) {
|
||||||
f := func(phi, vExpected float64) {
|
f := func(phi, vExpected float64) {
|
||||||
t.Helper()
|
t.Helper()
|
||||||
|
@ -5,6 +5,7 @@
|
|||||||
* FEATURE: optimize Consul service discovery speed when discovering big number of services. See https://github.com/VictoriaMetrics/VictoriaMetrics/issues/574
|
* FEATURE: optimize Consul service discovery speed when discovering big number of services. See https://github.com/VictoriaMetrics/VictoriaMetrics/issues/574
|
||||||
* FEATURE: add `label_uppercase(q, label1, ... labelN)` and `label_lowercase(q, label1, ... labelN)` function to [MetricsQL](https://victoriametrics.github.io/MetricsQL.html)
|
* FEATURE: add `label_uppercase(q, label1, ... labelN)` and `label_lowercase(q, label1, ... labelN)` function to [MetricsQL](https://victoriametrics.github.io/MetricsQL.html)
|
||||||
for uppercasing and lowercasing values for the given labels. See https://github.com/VictoriaMetrics/VictoriaMetrics/issues/936
|
for uppercasing and lowercasing values for the given labels. See https://github.com/VictoriaMetrics/VictoriaMetrics/issues/936
|
||||||
|
* FEATURE: add `count_eq_over_time(m[d], N)` and `count_ne_over_time(m[d], N)` for counting the number of samples for `m` over `d` that (equal / not equal) to `N`.
|
||||||
* FEATURE: do not print usage info for all the command-line flags when incorrect command-line flag is passed. Previously it could be hard reading the error message
|
* FEATURE: do not print usage info for all the command-line flags when incorrect command-line flag is passed. Previously it could be hard reading the error message
|
||||||
about incorrect command-line flag because of too big usage info for all the flags.
|
about incorrect command-line flag because of too big usage info for all the flags.
|
||||||
|
|
||||||
|
@ -123,6 +123,8 @@ This functionality can be tried at [an editable Grafana dashboard](http://play-g
|
|||||||
Example: `share_gt_over_time(up[24h], 0)` - returns service availability for the last 24 hours.
|
Example: `share_gt_over_time(up[24h], 0)` - returns service availability for the last 24 hours.
|
||||||
- `count_le_over_time(m[d], le)` - returns the number of raw samples for `m` over `d`, which don't exceed `le`.
|
- `count_le_over_time(m[d], le)` - returns the number of raw samples for `m` over `d`, which don't exceed `le`.
|
||||||
- `count_gt_over_time(m[d], gt)` - returns the number of raw samples for `m` over `d`, which are bigger than `gt`.
|
- `count_gt_over_time(m[d], gt)` - returns the number of raw samples for `m` over `d`, which are bigger than `gt`.
|
||||||
|
- `count_eq_over_time(m[d], N)` - returns the number of raw samples for `m` over `d` with values equal to `N`.
|
||||||
|
- `count_ne_over_time(m[d], N)` - returns the number of raw samples for `m` over `d` with values not equal to `N`.
|
||||||
- `tmin_over_time(m[d])` - returns timestamp for the minimum value for `m` over `d` time range.
|
- `tmin_over_time(m[d])` - returns timestamp for the minimum value for `m` over `d` time range.
|
||||||
- `tmax_over_time(m[d])` - returns timestamp for the maximum value for `m` over `d` time range.
|
- `tmax_over_time(m[d])` - returns timestamp for the maximum value for `m` over `d` time range.
|
||||||
- `aggr_over_time(("aggr_func1", "aggr_func2", ...), m[d])` - simultaneously calculates all the listed `aggr_func*` for `m` over `d` time range.
|
- `aggr_over_time(("aggr_func1", "aggr_func2", ...), m[d])` - simultaneously calculates all the listed `aggr_func*` for `m` over `d` time range.
|
||||||
|
2
go.mod
2
go.mod
@ -8,7 +8,7 @@ require (
|
|||||||
// like https://github.com/valyala/fasthttp/commit/996610f021ff45fdc98c2ce7884d5fa4e7f9199b
|
// like https://github.com/valyala/fasthttp/commit/996610f021ff45fdc98c2ce7884d5fa4e7f9199b
|
||||||
github.com/VictoriaMetrics/fasthttp v1.0.9
|
github.com/VictoriaMetrics/fasthttp v1.0.9
|
||||||
github.com/VictoriaMetrics/metrics v1.12.3
|
github.com/VictoriaMetrics/metrics v1.12.3
|
||||||
github.com/VictoriaMetrics/metricsql v0.8.0
|
github.com/VictoriaMetrics/metricsql v0.9.0
|
||||||
github.com/aws/aws-sdk-go v1.36.0
|
github.com/aws/aws-sdk-go v1.36.0
|
||||||
github.com/cespare/xxhash/v2 v2.1.1
|
github.com/cespare/xxhash/v2 v2.1.1
|
||||||
github.com/golang/snappy v0.0.2
|
github.com/golang/snappy v0.0.2
|
||||||
|
4
go.sum
4
go.sum
@ -45,8 +45,8 @@ github.com/VictoriaMetrics/fasthttp v1.0.9/go.mod h1:3SeUL4zwB/p/a9aEeRc6gdlbrtN
|
|||||||
github.com/VictoriaMetrics/metrics v1.12.2/go.mod h1:Z1tSfPfngDn12bTfZSCqArT3OPY3u88J12hSoOhuiRE=
|
github.com/VictoriaMetrics/metrics v1.12.2/go.mod h1:Z1tSfPfngDn12bTfZSCqArT3OPY3u88J12hSoOhuiRE=
|
||||||
github.com/VictoriaMetrics/metrics v1.12.3 h1:Fe6JHC6MSEKa+BtLhPN8WIvS+HKPzMc2evEpNeCGy7I=
|
github.com/VictoriaMetrics/metrics v1.12.3 h1:Fe6JHC6MSEKa+BtLhPN8WIvS+HKPzMc2evEpNeCGy7I=
|
||||||
github.com/VictoriaMetrics/metrics v1.12.3/go.mod h1:Z1tSfPfngDn12bTfZSCqArT3OPY3u88J12hSoOhuiRE=
|
github.com/VictoriaMetrics/metrics v1.12.3/go.mod h1:Z1tSfPfngDn12bTfZSCqArT3OPY3u88J12hSoOhuiRE=
|
||||||
github.com/VictoriaMetrics/metricsql v0.8.0 h1:fUZWNjXYJhiCKoEXr86pM4RaAxfA3SqkAhJLe1gr/mo=
|
github.com/VictoriaMetrics/metricsql v0.9.0 h1:mO4YmVRVHQmipTHcSMlCJ7Rctsol7vlu1l2ifh+ibqI=
|
||||||
github.com/VictoriaMetrics/metricsql v0.8.0/go.mod h1:ylO7YITho/Iw6P71oEaGyHbO94bGoGtzWfLGqFhMIg8=
|
github.com/VictoriaMetrics/metricsql v0.9.0/go.mod h1:ylO7YITho/Iw6P71oEaGyHbO94bGoGtzWfLGqFhMIg8=
|
||||||
github.com/allegro/bigcache v1.2.1-0.20190218064605-e24eb225f156 h1:eMwmnE/GDgah4HI848JfFxHt+iPb26b4zyfspmqY0/8=
|
github.com/allegro/bigcache v1.2.1-0.20190218064605-e24eb225f156 h1:eMwmnE/GDgah4HI848JfFxHt+iPb26b4zyfspmqY0/8=
|
||||||
github.com/allegro/bigcache v1.2.1-0.20190218064605-e24eb225f156/go.mod h1:Cb/ax3seSYIx7SuZdm2G2xzfwmv3TPSk2ucNfQESPXM=
|
github.com/allegro/bigcache v1.2.1-0.20190218064605-e24eb225f156/go.mod h1:Cb/ax3seSYIx7SuZdm2G2xzfwmv3TPSk2ucNfQESPXM=
|
||||||
github.com/andybalholm/brotli v1.0.0/go.mod h1:loMXtMfwqflxFJPmdbJO0a3KNoPuLBgiu3qAvBg8x/Y=
|
github.com/andybalholm/brotli v1.0.0/go.mod h1:loMXtMfwqflxFJPmdbJO0a3KNoPuLBgiu3qAvBg8x/Y=
|
||||||
|
2
vendor/github.com/VictoriaMetrics/metricsql/rollup.go
generated
vendored
2
vendor/github.com/VictoriaMetrics/metricsql/rollup.go
generated
vendored
@ -49,6 +49,8 @@ var rollupFuncs = map[string]bool{
|
|||||||
"share_gt_over_time": true,
|
"share_gt_over_time": true,
|
||||||
"count_le_over_time": true,
|
"count_le_over_time": true,
|
||||||
"count_gt_over_time": true,
|
"count_gt_over_time": true,
|
||||||
|
"count_eq_over_time": true,
|
||||||
|
"count_ne_over_time": true,
|
||||||
"histogram_over_time": true,
|
"histogram_over_time": true,
|
||||||
"rollup": true,
|
"rollup": true,
|
||||||
"rollup_rate": true,
|
"rollup_rate": true,
|
||||||
|
2
vendor/modules.txt
vendored
2
vendor/modules.txt
vendored
@ -16,7 +16,7 @@ github.com/VictoriaMetrics/fasthttp/fasthttputil
|
|||||||
github.com/VictoriaMetrics/fasthttp/stackless
|
github.com/VictoriaMetrics/fasthttp/stackless
|
||||||
# github.com/VictoriaMetrics/metrics v1.12.3
|
# github.com/VictoriaMetrics/metrics v1.12.3
|
||||||
github.com/VictoriaMetrics/metrics
|
github.com/VictoriaMetrics/metrics
|
||||||
# github.com/VictoriaMetrics/metricsql v0.8.0
|
# github.com/VictoriaMetrics/metricsql v0.9.0
|
||||||
github.com/VictoriaMetrics/metricsql
|
github.com/VictoriaMetrics/metricsql
|
||||||
github.com/VictoriaMetrics/metricsql/binaryop
|
github.com/VictoriaMetrics/metricsql/binaryop
|
||||||
# github.com/aws/aws-sdk-go v1.36.0
|
# github.com/aws/aws-sdk-go v1.36.0
|
||||||
|
Loading…
Reference in New Issue
Block a user