MemTableIterator not to reference Memtable

Summary: In one of the perf, I shows 10%-25% CPU costs of MemTableIterator.Seek(), when doing dynamic prefix seek, are spent on checking whether we need to do bloom filter check or finding out the prefix extractor. Seems that  more level of pointer checking makes CPU cache miss more likely. This patch makes things slightly simpler by copying pointer of bloom of prefix extractor into the iterator.

Test Plan: make all check

Reviewers: haobo, ljin

Reviewed By: ljin

CC: igor, dhruba, yhchiang, leveldb

Differential Revision: https://reviews.facebook.net/D17247
main
sdong 11 years ago
parent c8bb79978e
commit 2d3468c293
  1. 22
      db/memtable.cc

@ -155,22 +155,24 @@ const char* EncodeKey(std::string* scratch, const Slice& target) {
class MemTableIterator: public Iterator { class MemTableIterator: public Iterator {
public: public:
MemTableIterator(const MemTable& mem, const ReadOptions& options) MemTableIterator(const MemTable& mem, const ReadOptions& options)
: mem_(mem), iter_(), dynamic_prefix_seek_(false), valid_(false) { : bloom_(nullptr),
prefix_extractor_(mem.prefix_extractor_),
iter_(),
valid_(false) {
if (options.prefix) { if (options.prefix) {
iter_.reset(mem_.table_->GetPrefixIterator(*options.prefix)); iter_.reset(mem.table_->GetPrefixIterator(*options.prefix));
} else if (options.prefix_seek) { } else if (options.prefix_seek) {
dynamic_prefix_seek_ = true; bloom_ = mem.prefix_bloom_.get();
iter_.reset(mem_.table_->GetDynamicPrefixIterator()); iter_.reset(mem.table_->GetDynamicPrefixIterator());
} else { } else {
iter_.reset(mem_.table_->GetIterator()); iter_.reset(mem.table_->GetIterator());
} }
} }
virtual bool Valid() const { return valid_; } virtual bool Valid() const { return valid_; }
virtual void Seek(const Slice& k) { virtual void Seek(const Slice& k) {
if (dynamic_prefix_seek_ && mem_.prefix_bloom_ && if (bloom_ != nullptr &&
!mem_.prefix_bloom_->MayContain( !bloom_->MayContain(prefix_extractor_->Transform(ExtractUserKey(k)))) {
mem_.prefix_extractor_->Transform(ExtractUserKey(k)))) {
valid_ = false; valid_ = false;
return; return;
} }
@ -208,9 +210,9 @@ class MemTableIterator: public Iterator {
virtual Status status() const { return Status::OK(); } virtual Status status() const { return Status::OK(); }
private: private:
const MemTable& mem_; DynamicBloom* bloom_;
const SliceTransform* const prefix_extractor_;
std::shared_ptr<MemTableRep::Iterator> iter_; std::shared_ptr<MemTableRep::Iterator> iter_;
bool dynamic_prefix_seek_;
bool valid_; bool valid_;
// No copying allowed // No copying allowed

Loading…
Cancel
Save