mirror of https://github.com/prometheus/prometheus
fix resets function for histograms
Signed-off-by: Neeraj Gartia <neerajgartia211002@gmail.com>pull/15527/head
parent
48287b15d4
commit
4aeed2c4b1
|
@ -1400,28 +1400,42 @@ func funcResets(vals []parser.Value, args parser.Expressions, enh *EvalNodeHelpe
|
||||||
floats := vals[0].(Matrix)[0].Floats
|
floats := vals[0].(Matrix)[0].Floats
|
||||||
histograms := vals[0].(Matrix)[0].Histograms
|
histograms := vals[0].(Matrix)[0].Histograms
|
||||||
resets := 0
|
resets := 0
|
||||||
|
if len(floats) == 0 && len(histograms) == 0 {
|
||||||
if len(floats) > 1 {
|
return enh.Out, nil
|
||||||
prev := floats[0].F
|
|
||||||
for _, sample := range floats[1:] {
|
|
||||||
current := sample.F
|
|
||||||
if current < prev {
|
|
||||||
resets++
|
|
||||||
}
|
|
||||||
prev = current
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if len(histograms) > 1 {
|
var prevSample, curSample Sample
|
||||||
prev := histograms[0].H
|
for iFloat, iHistogram := 0, 0; iFloat < len(floats) || iHistogram < len(histograms); {
|
||||||
for _, sample := range histograms[1:] {
|
switch {
|
||||||
current := sample.H
|
// Process a float sample if no histogram sample remains or its timestamp is earlier.
|
||||||
if current.DetectReset(prev) {
|
// Process a histogram sample if no float sample remains or its timestamp is earlier.
|
||||||
|
case iHistogram >= len(histograms) || iFloat < len(floats) && floats[iFloat].T < histograms[iHistogram].T:
|
||||||
|
curSample.F = floats[iFloat].F
|
||||||
|
curSample.H = nil
|
||||||
|
iFloat++
|
||||||
|
case iFloat >= len(floats) || iHistogram < len(histograms) && floats[iFloat].T > histograms[iHistogram].T:
|
||||||
|
curSample.H = histograms[iHistogram].H
|
||||||
|
iHistogram++
|
||||||
|
}
|
||||||
|
// Skip the comparison for the first sample, just initialize prevSample.
|
||||||
|
if iFloat+iHistogram == 1 {
|
||||||
|
prevSample = curSample
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
switch {
|
||||||
|
case prevSample.H == nil && curSample.H == nil:
|
||||||
|
if curSample.F < prevSample.F {
|
||||||
resets++
|
resets++
|
||||||
}
|
}
|
||||||
prev = current
|
case prevSample.H != nil && curSample.H == nil, prevSample.H == nil && curSample.H != nil:
|
||||||
|
resets++
|
||||||
|
case prevSample.H != nil && curSample.H != nil:
|
||||||
|
if curSample.H.DetectReset(prevSample.H) {
|
||||||
|
resets++
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
prevSample = curSample
|
||||||
|
}
|
||||||
|
|
||||||
return append(enh.Out, Sample{F: float64(resets)}), nil
|
return append(enh.Out, Sample{F: float64(resets)}), nil
|
||||||
}
|
}
|
||||||
|
@ -1441,17 +1455,13 @@ func funcChanges(vals []parser.Value, args parser.Expressions, enh *EvalNodeHelp
|
||||||
// Process a float sample if no histogram sample remains or its timestamp is earlier.
|
// Process a float sample if no histogram sample remains or its timestamp is earlier.
|
||||||
// Process a histogram sample if no float sample remains or its timestamp is earlier.
|
// Process a histogram sample if no float sample remains or its timestamp is earlier.
|
||||||
case iHistogram >= len(histograms) || iFloat < len(floats) && floats[iFloat].T < histograms[iHistogram].T:
|
case iHistogram >= len(histograms) || iFloat < len(floats) && floats[iFloat].T < histograms[iHistogram].T:
|
||||||
{
|
|
||||||
curSample.F = floats[iFloat].F
|
curSample.F = floats[iFloat].F
|
||||||
curSample.H = nil
|
curSample.H = nil
|
||||||
iFloat++
|
iFloat++
|
||||||
}
|
|
||||||
case iFloat >= len(floats) || iHistogram < len(histograms) && floats[iFloat].T > histograms[iHistogram].T:
|
case iFloat >= len(floats) || iHistogram < len(histograms) && floats[iFloat].T > histograms[iHistogram].T:
|
||||||
{
|
|
||||||
curSample.H = histograms[iHistogram].H
|
curSample.H = histograms[iHistogram].H
|
||||||
iHistogram++
|
iHistogram++
|
||||||
}
|
}
|
||||||
}
|
|
||||||
// Skip the comparison for the first sample, just initialize prevSample.
|
// Skip the comparison for the first sample, just initialize prevSample.
|
||||||
if iFloat+iHistogram == 1 {
|
if iFloat+iHistogram == 1 {
|
||||||
prevSample = curSample
|
prevSample = curSample
|
||||||
|
@ -1459,22 +1469,16 @@ func funcChanges(vals []parser.Value, args parser.Expressions, enh *EvalNodeHelp
|
||||||
}
|
}
|
||||||
switch {
|
switch {
|
||||||
case prevSample.H == nil && curSample.H == nil:
|
case prevSample.H == nil && curSample.H == nil:
|
||||||
{
|
|
||||||
if curSample.F != prevSample.F && !(math.IsNaN(curSample.F) && math.IsNaN(prevSample.F)) {
|
if curSample.F != prevSample.F && !(math.IsNaN(curSample.F) && math.IsNaN(prevSample.F)) {
|
||||||
changes++
|
changes++
|
||||||
}
|
}
|
||||||
}
|
|
||||||
case prevSample.H != nil && curSample.H == nil, prevSample.H == nil && curSample.H != nil:
|
case prevSample.H != nil && curSample.H == nil, prevSample.H == nil && curSample.H != nil:
|
||||||
{
|
|
||||||
changes++
|
changes++
|
||||||
}
|
|
||||||
case prevSample.H != nil && curSample.H != nil:
|
case prevSample.H != nil && curSample.H != nil:
|
||||||
{
|
|
||||||
if !curSample.H.Equals(prevSample.H) {
|
if !curSample.H.Equals(prevSample.H) {
|
||||||
changes++
|
changes++
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
prevSample = curSample
|
prevSample = curSample
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -5,7 +5,7 @@ load 5m
|
||||||
http_requests{path="/biz"} 0 0 0 0 0 1 1 1 1 1
|
http_requests{path="/biz"} 0 0 0 0 0 1 1 1 1 1
|
||||||
http_requests_histogram{path="/foo"} {{schema:0 sum:1 count:1}}x9
|
http_requests_histogram{path="/foo"} {{schema:0 sum:1 count:1}}x9
|
||||||
http_requests_histogram{path="/bar"} 0 0 0 0 0 0 0 0 {{schema:0 sum:1 count:1}} {{schema:0 sum:1 count:1}}
|
http_requests_histogram{path="/bar"} 0 0 0 0 0 0 0 0 {{schema:0 sum:1 count:1}} {{schema:0 sum:1 count:1}}
|
||||||
http_requests_histogram{path="/biz"} 0 1 0 2 0 3 0 {{schema:0 sum:1 count:1}} {{schema:0 sum:2 count:2}} {{schema:0 sum:1 count:1}}
|
http_requests_histogram{path="/biz"} 0 1 0 2 0 3 0 {{schema:0 sum:1 count:1 z_bucket_w:0.001 z_bucket:2}} {{schema:0 sum:2 count:2 z_bucket_w:0.001 z_bucket:1}} {{schema:0 sum:1 count:1 z_bucket_w:0.001 z_bucket:2}}
|
||||||
|
|
||||||
# Tests for resets().
|
# Tests for resets().
|
||||||
eval instant at 50m resets(http_requests[5m])
|
eval instant at 50m resets(http_requests[5m])
|
||||||
|
@ -42,6 +42,18 @@ eval instant at 50m resets(http_requests[50m])
|
||||||
|
|
||||||
eval instant at 50m resets(nonexistent_metric[50m])
|
eval instant at 50m resets(nonexistent_metric[50m])
|
||||||
|
|
||||||
|
# Test for mix of floats and histograms.
|
||||||
|
|
||||||
|
eval instant at 50m resets(http_requests_histogram[6m])
|
||||||
|
{path="/foo"} 0
|
||||||
|
{path="/bar"} 0
|
||||||
|
{path="/biz"} 0
|
||||||
|
|
||||||
|
eval instant at 50m resets(http_requests_histogram[60m])
|
||||||
|
{path="/foo"} 0
|
||||||
|
{path="/bar"} 1
|
||||||
|
{path="/biz"} 6
|
||||||
|
|
||||||
# Tests for changes().
|
# Tests for changes().
|
||||||
eval instant at 50m changes(http_requests[5m])
|
eval instant at 50m changes(http_requests[5m])
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue