WAL loading: don't send empty buffers over chan (#11319)

If some shards did not get any samples mapped, the buffer will be empty
so sending it over the chan to `processWALSamples()` is a waste of time.

This is especially likely now we are checking `minValidTime` before
sending.

Signed-off-by: Bryan Boreham <bjboreham@gmail.com>

Signed-off-by: Bryan Boreham <bjboreham@gmail.com>
pre-ooo
Bryan Boreham 2022-09-20 15:13:30 +01:00 committed by GitHub
parent 9591103bb9
commit af6167df58
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
1 changed files with 7 additions and 2 deletions

View File

@ -247,8 +247,10 @@ Outer:
m = len(samples) m = len(samples)
} }
for i := 0; i < n; i++ { for i := 0; i < n; i++ {
if shards[i] == nil {
shards[i] = processors[i].reuseBuf() shards[i] = processors[i].reuseBuf()
} }
}
for _, sam := range samples[:m] { for _, sam := range samples[:m] {
if sam.T < minValidTime { if sam.T < minValidTime {
continue // Before minValidTime: discard. continue // Before minValidTime: discard.
@ -260,7 +262,10 @@ Outer:
shards[mod] = append(shards[mod], sam) shards[mod] = append(shards[mod], sam)
} }
for i := 0; i < n; i++ { for i := 0; i < n; i++ {
if len(shards[i]) > 0 {
processors[i].input <- walSubsetProcessorInputItem{samples: shards[i]} processors[i].input <- walSubsetProcessorInputItem{samples: shards[i]}
shards[i] = nil
}
} }
samples = samples[m:] samples = samples[m:]
} }