mirror of
https://github.com/prometheus/prometheus.git
synced 2025-01-12 06:17:27 -08:00
Final delete fixes.
* Make sure no reads happen on the block when delete is in progress. * Fix bugs in compaction. Signed-off-by: Goutham Veeramachaneni <cs14btech11014@iith.ac.in>
This commit is contained in:
parent
c211ec4f49
commit
6febabeb28
15
block.go
15
block.go
|
@ -234,7 +234,7 @@ func (pb *persistedBlock) Delete(mint, maxt int64, ms ...labels.Matcher) error {
|
|||
ir := pb.indexr
|
||||
|
||||
// Choose only valid postings which have chunks in the time-range.
|
||||
delStones := map[uint32]intervals{}
|
||||
newStones := map[uint32]intervals{}
|
||||
|
||||
Outer:
|
||||
for p.Next() {
|
||||
|
@ -259,7 +259,7 @@ Outer:
|
|||
if mint < chunks[0].MinTime {
|
||||
mint = chunks[0].MinTime
|
||||
}
|
||||
delStones[p.At()] = intervals{{mint, maxtime}}
|
||||
newStones[p.At()] = intervals{{mint, maxtime}}
|
||||
continue Outer
|
||||
}
|
||||
}
|
||||
|
@ -270,18 +270,15 @@ Outer:
|
|||
}
|
||||
|
||||
// Merge the current and new tombstones.
|
||||
for k, v := range pb.tombstones {
|
||||
for _, itv := range v {
|
||||
delStones[k] = delStones[k].add(itv)
|
||||
}
|
||||
for k, v := range newStones {
|
||||
pb.tombstones[k] = pb.tombstones[k].add(v[0])
|
||||
}
|
||||
tombreader := newTombstoneReader(delStones)
|
||||
|
||||
if err := writeTombstoneFile(pb.dir, tombreader); err != nil {
|
||||
if err := writeTombstoneFile(pb.dir, pb.tombstones); err != nil {
|
||||
return err
|
||||
}
|
||||
|
||||
pb.meta.NumTombstones = int64(len(delStones))
|
||||
pb.meta.NumTombstones = int64(len(pb.tombstones))
|
||||
return writeMetaFile(pb.dir, &pb.meta)
|
||||
}
|
||||
|
||||
|
|
20
compact.go
20
compact.go
|
@ -263,12 +263,8 @@ func (c *compactor) write(uid ulid.ULID, blocks ...Block) (err error) {
|
|||
}
|
||||
|
||||
// Create an empty tombstones file.
|
||||
tf, err := os.Create(filepath.Join(tmp, tombstoneFilename))
|
||||
if err != nil {
|
||||
return errors.Wrap(err, "touch tombstones file")
|
||||
}
|
||||
if err := tf.Close(); err != nil {
|
||||
return errors.Wrap(err, "close tombstones file")
|
||||
if err := writeTombstoneFile(tmp, newEmptyTombstoneReader()); err != nil {
|
||||
return errors.Wrap(err, "write new tombstones file")
|
||||
}
|
||||
|
||||
// Block successfully written, make visible and remove old ones.
|
||||
|
@ -444,11 +440,6 @@ func (c *compactionSeriesSet) Next() bool {
|
|||
chks := make([]*ChunkMeta, 0, len(c.c))
|
||||
for _, chk := range c.c {
|
||||
if !(interval{chk.MinTime, chk.MaxTime}.isSubrange(c.intervals)) {
|
||||
chk.Chunk, c.err = c.chunks.Chunk(chk.Ref)
|
||||
if c.err != nil {
|
||||
return false
|
||||
}
|
||||
|
||||
chks = append(chks, chk)
|
||||
}
|
||||
}
|
||||
|
@ -456,6 +447,13 @@ func (c *compactionSeriesSet) Next() bool {
|
|||
c.c = chks
|
||||
}
|
||||
|
||||
for _, chk := range c.c {
|
||||
chk.Chunk, c.err = c.chunks.Chunk(chk.Ref)
|
||||
if c.err != nil {
|
||||
return false
|
||||
}
|
||||
}
|
||||
|
||||
return true
|
||||
}
|
||||
|
||||
|
|
11
db.go
11
db.go
|
@ -424,6 +424,7 @@ func (db *DB) reloadBlocks() error {
|
|||
if err := validateBlockSequence(blocks); err != nil {
|
||||
return errors.Wrap(err, "invalid block sequence")
|
||||
}
|
||||
|
||||
// Close all opened blocks that no longer exist after we returned all locks.
|
||||
for _, b := range db.blocks {
|
||||
if _, ok := exist[b.Meta().ULID]; !ok {
|
||||
|
@ -670,22 +671,24 @@ func (a *dbAppender) Rollback() error {
|
|||
func (db *DB) Delete(mint, maxt int64, ms ...labels.Matcher) error {
|
||||
db.cmtx.Lock()
|
||||
defer db.cmtx.Unlock()
|
||||
db.mtx.Lock()
|
||||
defer db.mtx.Unlock()
|
||||
|
||||
db.mtx.RLock()
|
||||
blocks := db.blocksForInterval(mint, maxt)
|
||||
db.mtx.RUnlock()
|
||||
|
||||
var g errgroup.Group
|
||||
|
||||
for _, b := range blocks {
|
||||
g.Go(func() error { return b.Delete(mint, maxt, ms...) })
|
||||
g.Go(func(b Block) func() error {
|
||||
return func() error { return b.Delete(mint, maxt, ms...) }
|
||||
}(b))
|
||||
}
|
||||
|
||||
if err := g.Wait(); err != nil {
|
||||
return err
|
||||
}
|
||||
|
||||
return db.reloadBlocks()
|
||||
return nil
|
||||
}
|
||||
|
||||
// appendable returns a copy of a slice of HeadBlocks that can still be appended to.
|
||||
|
|
Loading…
Reference in a new issue