mirror of
https://github.com/VictoriaMetrics/VictoriaMetrics.git
synced 2025-01-20 23:39:48 +01:00
app/vmselect/promql: properly handle Prometheus staleness marks in removeCounterResets functions
Prometheus stalenss marks shouldn't be changed in removeCounterResets. Otherwise they will be converted to an ordinary NaN values, which couldn't be removed in dropStaleNaNs() function later. This may result in incorrect calculations for rollup functions. Updates https://github.com/VictoriaMetrics/VictoriaMetrics/issues/1526
This commit is contained in:
parent
7d0e64dcc0
commit
af4a306d7b
@ -704,8 +704,6 @@ func getMaxPrevInterval(scrapeInterval int64) int64 {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func removeCounterResets(values []float64) {
|
func removeCounterResets(values []float64) {
|
||||||
// There is no need in handling NaNs here, since they are impossible
|
|
||||||
// on values from vmstorage.
|
|
||||||
if len(values) == 0 {
|
if len(values) == 0 {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
@ -723,9 +721,11 @@ func removeCounterResets(values []float64) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
prevValue = v
|
prevValue = v
|
||||||
|
if !decimal.IsStaleNaN(v) {
|
||||||
values[i] = v + correction
|
values[i] = v + correction
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
func deltaValues(values []float64) {
|
func deltaValues(values []float64) {
|
||||||
// There is no need in handling NaNs here, since they are impossible
|
// There is no need in handling NaNs here, since they are impossible
|
||||||
|
Loading…
Reference in New Issue
Block a user