mirror of
https://github.com/prometheus/prometheus.git
synced 2025-01-14 07:17:52 -08:00
Code Review: Fix to-disk queue infinite growth.
We discovered a bug while manually testing this branch on a live instance, whereby the to-disk queue was never actually dumped to disk.
This commit is contained in:
parent
285a8b701b
commit
b586801830
|
@ -56,7 +56,6 @@ type TieredStorage struct {
|
||||||
// BUG(matt): This introduces a Law of Demeter violation. Ugh.
|
// BUG(matt): This introduces a Law of Demeter violation. Ugh.
|
||||||
DiskStorage *LevelDBMetricPersistence
|
DiskStorage *LevelDBMetricPersistence
|
||||||
|
|
||||||
// BUG(matt): Replace this with a map?
|
|
||||||
appendToDiskQueue chan model.Samples
|
appendToDiskQueue chan model.Samples
|
||||||
|
|
||||||
diskFrontier *diskFrontier
|
diskFrontier *diskFrontier
|
||||||
|
@ -183,7 +182,7 @@ func (t *TieredStorage) Serve() {
|
||||||
for {
|
for {
|
||||||
select {
|
select {
|
||||||
case <-flushMemoryTicker.C:
|
case <-flushMemoryTicker.C:
|
||||||
t.flushMemory()
|
t.flushMemory(t.memoryTTL)
|
||||||
case viewRequest := <-t.viewQueue:
|
case viewRequest := <-t.viewQueue:
|
||||||
t.renderView(viewRequest)
|
t.renderView(viewRequest)
|
||||||
case drainingDone := <-t.draining:
|
case drainingDone := <-t.draining:
|
||||||
|
@ -203,14 +202,16 @@ func (t *TieredStorage) reportQueues() {
|
||||||
}
|
}
|
||||||
|
|
||||||
func (t *TieredStorage) Flush() {
|
func (t *TieredStorage) Flush() {
|
||||||
t.flushMemory()
|
t.flushMemory(0)
|
||||||
}
|
}
|
||||||
|
|
||||||
func (t *TieredStorage) flushMemory() {
|
func (t *TieredStorage) flushMemory(ttl time.Duration) {
|
||||||
t.memoryArena.RLock()
|
t.memoryArena.RLock()
|
||||||
defer t.memoryArena.RUnlock()
|
defer t.memoryArena.RUnlock()
|
||||||
|
|
||||||
cutOff := time.Now().Add(-1 * t.memoryTTL)
|
cutOff := time.Now().Add(-1 * ttl)
|
||||||
|
|
||||||
|
log.Println("Flushing...")
|
||||||
|
|
||||||
for _, stream := range t.memoryArena.fingerprintToSeries {
|
for _, stream := range t.memoryArena.fingerprintToSeries {
|
||||||
finder := func(i int) bool {
|
finder := func(i int) bool {
|
||||||
|
@ -237,6 +238,20 @@ func (t *TieredStorage) flushMemory() {
|
||||||
stream.values = toKeep
|
stream.values = toKeep
|
||||||
stream.Unlock()
|
stream.Unlock()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
queueLength := len(t.appendToDiskQueue)
|
||||||
|
if queueLength > 0 {
|
||||||
|
log.Printf("Writing %d samples ...", queueLength)
|
||||||
|
samples := model.Samples{}
|
||||||
|
for i := 0; i < queueLength; i++ {
|
||||||
|
chunk := <-t.appendToDiskQueue
|
||||||
|
samples = append(samples, chunk...)
|
||||||
|
}
|
||||||
|
|
||||||
|
t.DiskStorage.AppendSamples(samples)
|
||||||
|
}
|
||||||
|
|
||||||
|
log.Println("Done flushing...")
|
||||||
}
|
}
|
||||||
|
|
||||||
func (t *TieredStorage) Close() {
|
func (t *TieredStorage) Close() {
|
||||||
|
|
Loading…
Reference in a new issue