From e5991144d2b52715938b4a7054442a376ff17f63 Mon Sep 17 00:00:00 2001 From: Prateek Rungta Date: Thu, 6 Sep 2018 17:13:04 -0400 Subject: [PATCH] Eliminate locking from postings lists --- src/m3ninx/postings/roaring/roaring.go | 52 +++----------------------- 1 file changed, 5 insertions(+), 47 deletions(-) diff --git a/src/m3ninx/postings/roaring/roaring.go b/src/m3ninx/postings/roaring/roaring.go index 755a20f46b..61adc99ac6 100644 --- a/src/m3ninx/postings/roaring/roaring.go +++ b/src/m3ninx/postings/roaring/roaring.go @@ -22,7 +22,6 @@ package roaring import ( "errors" - "sync" "github.com/m3db/m3/src/m3ninx/postings" "github.com/m3db/m3/src/m3ninx/x" @@ -37,9 +36,8 @@ var ( errIteratorClosed = errors.New("iterator has been closed") ) -// postingsList wraps a Roaring Bitmap with a mutex for thread safety. +// postingsList wraps a Roaring Bitmap with the m3ninx pl API. type postingsList struct { - sync.RWMutex bitmap *roaring.Bitmap } @@ -51,9 +49,7 @@ func NewPostingsList() postings.MutableList { } func (d *postingsList) Insert(i postings.ID) { - d.Lock() d.bitmap.Add(uint32(i)) - d.Unlock() } func (d *postingsList) Intersect(other postings.List) error { @@ -62,11 +58,7 @@ func (d *postingsList) Intersect(other postings.List) error { return errIntersectRoaringOnly } - o.RLock() - d.Lock() d.bitmap.And(o.bitmap) - d.Unlock() - o.RUnlock() return nil } @@ -76,11 +68,7 @@ func (d *postingsList) Difference(other postings.List) error { return errDifferenceRoaringOnly } - o.RLock() - d.Lock() d.bitmap.AndNot(o.bitmap) - d.Unlock() - o.RUnlock() return nil } @@ -90,29 +78,21 @@ func (d *postingsList) Union(other postings.List) error { return errUnionRoaringOnly } - o.RLock() - d.Lock() d.bitmap.Or(o.bitmap) - d.Unlock() - o.RUnlock() return nil } func (d *postingsList) AddRange(min, max postings.ID) { - d.Lock() d.bitmap.AddRange(uint64(min), uint64(max)) - d.Unlock() } func (d *postingsList) AddIterator(iter postings.Iterator) error { safeIter := x.NewSafeCloser(iter) defer safeIter.Close() - d.Lock() for iter.Next() { d.bitmap.Add(uint32(iter.Current())) } - d.Unlock() if err := iter.Err(); err != nil { return err @@ -122,58 +102,39 @@ func (d *postingsList) AddIterator(iter postings.Iterator) error { } func (d *postingsList) RemoveRange(min, max postings.ID) { - d.Lock() d.bitmap.RemoveRange(uint64(min), uint64(max)) - d.Unlock() } func (d *postingsList) Reset() { - d.Lock() d.bitmap.Clear() - d.Unlock() } func (d *postingsList) Contains(i postings.ID) bool { - d.RLock() - contains := d.bitmap.Contains(uint32(i)) - d.RUnlock() - return contains + return d.bitmap.Contains(uint32(i)) } func (d *postingsList) IsEmpty() bool { - d.RLock() - empty := d.bitmap.IsEmpty() - d.RUnlock() - return empty + return d.bitmap.IsEmpty() } func (d *postingsList) Max() (postings.ID, error) { - d.RLock() if d.bitmap.IsEmpty() { - d.RUnlock() return 0, postings.ErrEmptyList } max := d.bitmap.Maximum() - d.RUnlock() return postings.ID(max), nil } func (d *postingsList) Min() (postings.ID, error) { - d.RLock() if d.bitmap.IsEmpty() { - d.RUnlock() return 0, postings.ErrEmptyList } min := d.bitmap.Minimum() - d.RUnlock() return postings.ID(min), nil } func (d *postingsList) Len() int { - d.RLock() - l := d.bitmap.GetCardinality() - d.RUnlock() - return int(l) + return int(d.bitmap.GetCardinality()) } func (d *postingsList) Iterator() postings.Iterator { @@ -183,15 +144,12 @@ func (d *postingsList) Iterator() postings.Iterator { } func (d *postingsList) Clone() postings.MutableList { - d.RLock() // TODO: It's cheaper to Clone than to cache roaring bitmaps, see // `postings_list_bench_test.go`. Their internals don't allow for // pooling at the moment. We should address this when get a chance // (move to another implementation / address deficiencies). - clone := d.bitmap.Clone() - d.RUnlock() return &postingsList{ - bitmap: clone, + bitmap: d.bitmap.Clone(), } }