mirror of
https://github.com/prometheus/prometheus.git
synced 2025-01-16 00:08:39 -08:00
6579dc3e40
The first sort in groupByFingerprint already ensures that all resulting sample
lists contain only one fingerprint. We also already assume that all
samples passed into AppendSamples (and thus groupByFingerprint) are
chronologically sorted within each fingerprint.
The extra chronological sort is thus superfluous. Furthermore, this
second sort didn't only sort chronologically, but also compared all
metric fingerprints again (although we already know that we're only
sorting within samples for the same fingerprint). This caused a huge
memory and runtime overhead.
In a heavily loaded real Prometheus, this brought down disk flush times
from ~9 minutes to ~1 minute.
OLD:
BenchmarkLevelDBAppendRepeatingValues 5 331391808 ns/op 44542953 B/op 597788 allocs/op
BenchmarkLevelDBAppendsRepeatingValues 5 329893512 ns/op 46968288 B/op 3104373 allocs/op
NEW:
BenchmarkLevelDBAppendRepeatingValues 5 299298635 ns/op 43329497 B/op 567616 allocs/op
BenchmarkLevelDBAppendsRepeatingValues 20 92204601 ns/op
|
||
---|---|---|
.. | ||
compaction_regression_test.go | ||
curator.go | ||
dto.go | ||
end_to_end_test.go | ||
freelist.go | ||
freelist_test.go | ||
index.go | ||
interface_test.go | ||
leveldb.go | ||
marshal.go | ||
memory.go | ||
memory_test.go | ||
objective.go | ||
operation.go | ||
operation_test.go | ||
processor.go | ||
processor_test.go | ||
regressions_test.go | ||
rule_integration_test.go | ||
sample_test.go | ||
samplekey.go | ||
stochastic_test.go | ||
test_helpers.go | ||
tiered.go | ||
tiered_test.go | ||
view.go | ||
view_test.go | ||
watermark.go |