mirror of https://github.com/prometheus/prometheus
Fix off-by-one error in funcHistogramQuantile / ensureMonotonic (#7393)
* Fix off-by-one error in funcHistogramQuantile / ensureMonotonic * Additional coverage for nonmonotonic histogram buckets Signed-off-by: Linas Medziunas <linas.medziunas@gmail.com>pull/7401/head
parent
abb4fba3c2
commit
7eaffa7180
|
@ -168,7 +168,7 @@ func coalesceBuckets(buckets buckets) buckets {
|
||||||
|
|
||||||
func ensureMonotonic(buckets buckets) {
|
func ensureMonotonic(buckets buckets) {
|
||||||
max := buckets[0].count
|
max := buckets[0].count
|
||||||
for i := range buckets[1:] {
|
for i := 1; i < len(buckets); i++ {
|
||||||
switch {
|
switch {
|
||||||
case buckets[i].count > max:
|
case buckets[i].count > max:
|
||||||
max = buckets[i].count
|
max = buckets[i].count
|
||||||
|
|
|
@ -151,21 +151,25 @@ eval instant at 50m histogram_quantile(0.5, rate(request_duration_seconds_bucket
|
||||||
|
|
||||||
# A histogram with nonmonotonic bucket counts. This may happen when recording
|
# A histogram with nonmonotonic bucket counts. This may happen when recording
|
||||||
# rule evaluation or federation races scrape ingestion, causing some buckets
|
# rule evaluation or federation races scrape ingestion, causing some buckets
|
||||||
# counts to be derived from fewer samples. The wrong answer we want to avoid
|
# counts to be derived from fewer samples.
|
||||||
# is for histogram_quantile(0.99, nonmonotonic_bucket) to return ~1000 instead
|
|
||||||
# of 1.
|
|
||||||
|
|
||||||
load 5m
|
load 5m
|
||||||
nonmonotonic_bucket{le="0.1"} 0+1x10
|
nonmonotonic_bucket{le="0.1"} 0+2x10
|
||||||
nonmonotonic_bucket{le="1"} 0+9x10
|
nonmonotonic_bucket{le="1"} 0+1x10
|
||||||
nonmonotonic_bucket{le="10"} 0+8x10
|
nonmonotonic_bucket{le="10"} 0+5x10
|
||||||
nonmonotonic_bucket{le="100"} 0+8x10
|
nonmonotonic_bucket{le="100"} 0+4x10
|
||||||
nonmonotonic_bucket{le="1000"} 0+9x10
|
nonmonotonic_bucket{le="1000"} 0+9x10
|
||||||
nonmonotonic_bucket{le="+Inf"} 0+9x10
|
nonmonotonic_bucket{le="+Inf"} 0+8x10
|
||||||
|
|
||||||
# Nonmonotonic buckets
|
# Nonmonotonic buckets
|
||||||
|
eval instant at 50m histogram_quantile(0.01, nonmonotonic_bucket)
|
||||||
|
{} 0.0045
|
||||||
|
|
||||||
|
eval instant at 50m histogram_quantile(0.5, nonmonotonic_bucket)
|
||||||
|
{} 8.5
|
||||||
|
|
||||||
eval instant at 50m histogram_quantile(0.99, nonmonotonic_bucket)
|
eval instant at 50m histogram_quantile(0.99, nonmonotonic_bucket)
|
||||||
{} 0.989875
|
{} 979.75
|
||||||
|
|
||||||
# Buckets with different representations of the same upper bound.
|
# Buckets with different representations of the same upper bound.
|
||||||
eval instant at 50m histogram_quantile(0.5, rate(mixed_bucket[5m]))
|
eval instant at 50m histogram_quantile(0.5, rate(mixed_bucket[5m]))
|
||||||
|
|
Loading…
Reference in New Issue