TSDB: OOO native histograms: prep for multiple ooo head chunks (#14850)
* tsdb: mmapCurrentOOOHeadChunk prepare for multiple ooo chunks Currently float samples can only create a single ooo head chunk, but native histograms can result in multiple due to counter resets, etc. Signed-off-by: György Krajcsovits <gyorgy.krajcsovits@grafana.com> * tsdb: getOOOSeriesChunks prepare for multiple ooo chunks Currently float samples can only create a single ooo head chunk, but native histograms can result in multiple due to counter resets, etc. Signed-off-by: György Krajcsovits <gyorgy.krajcsovits@grafana.com> --------- Signed-off-by: György Krajcsovits <gyorgy.krajcsovits@grafana.com>
This commit is contained in:
parent
4f81e077b3
commit
5aa3d8260a
@ -1469,13 +1469,13 @@ func (s *memSeries) mmapCurrentOOOHeadChunk(chunkDiskMapper *chunks.ChunkDiskMap
|
|||||||
handleChunkWriteError(err)
|
handleChunkWriteError(err)
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
chunkRefs := make([]chunks.ChunkDiskMapperRef, 0, 1)
|
chunkRefs := make([]chunks.ChunkDiskMapperRef, 0, len(chks))
|
||||||
for _, memchunk := range chks {
|
for _, memchunk := range chks {
|
||||||
if len(s.ooo.oooMmappedChunks) >= (oooChunkIDMask - 1) {
|
if len(s.ooo.oooMmappedChunks) >= (oooChunkIDMask - 1) {
|
||||||
level.Error(logger).Log("msg", "Too many OOO chunks, dropping data", "series", s.lset.String())
|
level.Error(logger).Log("msg", "Too many OOO chunks, dropping data", "series", s.lset.String())
|
||||||
break
|
break
|
||||||
}
|
}
|
||||||
chunkRef := chunkDiskMapper.WriteChunk(s.ref, s.ooo.oooHeadChunk.minTime, s.ooo.oooHeadChunk.maxTime, memchunk.chunk, true, handleChunkWriteError)
|
chunkRef := chunkDiskMapper.WriteChunk(s.ref, memchunk.minTime, memchunk.maxTime, memchunk.chunk, true, handleChunkWriteError)
|
||||||
chunkRefs = append(chunkRefs, chunkRef)
|
chunkRefs = append(chunkRefs, chunkRef)
|
||||||
s.ooo.oooMmappedChunks = append(s.ooo.oooMmappedChunks, &mmappedChunk{
|
s.ooo.oooMmappedChunks = append(s.ooo.oooMmappedChunks, &mmappedChunk{
|
||||||
ref: chunkRef,
|
ref: chunkRef,
|
||||||
|
@ -111,7 +111,7 @@ func getOOOSeriesChunks(s *memSeries, mint, maxt int64, lastGarbageCollectedMmap
|
|||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
for _, chk := range chks {
|
for _, chk := range chks {
|
||||||
addChunk(c.minTime, c.maxTime, ref, chk.chunk)
|
addChunk(chk.minTime, chk.maxTime, ref, chk.chunk)
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
var emptyChunk chunkenc.Chunk
|
var emptyChunk chunkenc.Chunk
|
||||||
|
Loading…
Reference in New Issue
Block a user