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
This commit is contained in:
parent
c8bb79978e
commit
2d3468c293
@ -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…
x
Reference in New Issue
Block a user