mirror of
https://github.com/prometheus/prometheus.git
synced 2025-01-26 05:01:23 -08:00
TSDB: Pre-size buffer to read samples from WAL
When reading the WAL this method is called with buffers from a pool, on multiple goroutines. Pre-allocating sufficient size avoids slow growth and many reallocations in `append`. Signed-off-by: Bryan Boreham <bjboreham@gmail.com>
This commit is contained in:
parent
a06c6680aa
commit
26fa2e8356
|
@ -304,6 +304,10 @@ func (d *Decoder) Samples(rec []byte, samples []RefSample) ([]RefSample, error)
|
||||||
baseRef = dec.Be64()
|
baseRef = dec.Be64()
|
||||||
baseTime = dec.Be64int64()
|
baseTime = dec.Be64int64()
|
||||||
)
|
)
|
||||||
|
// Allow 1 byte for each varint and 8 for the value; the output slice must be at least that big.
|
||||||
|
if minSize := dec.Len() / (1 + 1 + 8); cap(samples) < minSize {
|
||||||
|
samples = make([]RefSample, 0, minSize)
|
||||||
|
}
|
||||||
for len(dec.B) > 0 && dec.Err() == nil {
|
for len(dec.B) > 0 && dec.Err() == nil {
|
||||||
dref := dec.Varint64()
|
dref := dec.Varint64()
|
||||||
dtime := dec.Varint64()
|
dtime := dec.Varint64()
|
||||||
|
|
Loading…
Reference in a new issue