Mike Kolupaev 236d4c67e9 Less linear search in DBIter::Seek() when keys are overwritten a lot
Summary:
In one deployment we saw high latencies (presumably from slow iterator operations) and a lot of CPU time reported by perf with this stack:

```
  rocksdb::MergingIterator::Next
  rocksdb::DBIter::FindNextUserEntryInternal
  rocksdb::DBIter::Seek
```

I think what's happening is:
1. we create a snapshot iterator,
2. we do lots of Put()s for the same key x; this creates lots of entries in memtable,
3. we seek the iterator to a key slightly smaller than x,
4. the seek walks over lots of entries in memtable for key x, skipping them because of high sequence numbers.

CC IslamAbdelRahman
Closes https://github.com/facebook/rocksdb/pull/1413

Differential Revision: D4083879

Pulled By: IslamAbdelRahman

fbshipit-source-id: a83ddae
2016-11-28 10:24:11 -08:00
..
2016-11-21 12:24:13 -08:00
2016-11-19 14:24:12 -08:00
2016-11-23 09:24:15 -08:00
2016-11-23 09:24:15 -08:00
2016-11-03 18:54:20 -07:00
2016-09-13 21:11:59 -07:00
2016-11-21 18:09:13 -08:00
2016-11-21 18:09:13 -08:00
2016-11-04 12:09:22 -07:00
2016-11-21 18:09:13 -08:00
2016-11-21 18:09:13 -08:00
2016-11-21 18:09:13 -08:00
2016-11-23 09:24:15 -08:00
2016-11-10 11:09:22 -08:00
2016-09-27 18:20:57 -07:00
2016-11-21 12:24:13 -08:00
2016-07-08 17:50:51 -07:00
2016-10-13 08:48:40 -07:00
2016-07-08 17:50:51 -07:00
2016-11-03 18:54:20 -07:00
2016-11-21 12:24:13 -08:00
2016-11-19 14:24:12 -08:00
2016-09-27 18:20:57 -07:00
2016-09-27 18:20:57 -07:00
2016-07-13 15:36:22 -07:00
2016-11-21 18:09:13 -08:00
2016-11-21 18:09:13 -08:00