Change is_range_del_table_empty_ flag to atomic (#4801)

Summary:
To avoid a race on the flag, make it an atomic_bool. This
doesn't seem to significantly affect benchmarks.
Pull Request resolved: https://github.com/facebook/rocksdb/pull/4801

Differential Revision: D13523845

Pulled By: abhimadan

fbshipit-source-id: 3bc29f53c50a4e06cd9f8c6232a4bb221868e055
main
Abhishek Madan 6 years ago committed by Facebook Github Bot
parent 8bf73208a4
commit 02bfc5831e
  1. 7
      db/memtable.cc
  2. 2
      db/memtable.h

@ -414,7 +414,8 @@ InternalIterator* MemTable::NewIterator(const ReadOptions& read_options,
FragmentedRangeTombstoneIterator* MemTable::NewRangeTombstoneIterator( FragmentedRangeTombstoneIterator* MemTable::NewRangeTombstoneIterator(
const ReadOptions& read_options, SequenceNumber read_seq) { const ReadOptions& read_options, SequenceNumber read_seq) {
if (read_options.ignore_range_deletions || is_range_del_table_empty_) { if (read_options.ignore_range_deletions ||
is_range_del_table_empty_.load(std::memory_order_relaxed)) {
return nullptr; return nullptr;
} }
auto* unfragmented_iter = new MemTableIterator( auto* unfragmented_iter = new MemTableIterator(
@ -563,8 +564,8 @@ bool MemTable::Add(SequenceNumber s, ValueType type,
!first_seqno_.compare_exchange_weak(cur_earliest_seqno, s)) { !first_seqno_.compare_exchange_weak(cur_earliest_seqno, s)) {
} }
} }
if (is_range_del_table_empty_ && type == kTypeRangeDeletion) { if (type == kTypeRangeDeletion) {
is_range_del_table_empty_ = false; is_range_del_table_empty_.store(false, std::memory_order_relaxed);
} }
UpdateOldestKeyTime(); UpdateOldestKeyTime();
return true; return true;

@ -409,7 +409,7 @@ class MemTable {
ConcurrentArena arena_; ConcurrentArena arena_;
std::unique_ptr<MemTableRep> table_; std::unique_ptr<MemTableRep> table_;
std::unique_ptr<MemTableRep> range_del_table_; std::unique_ptr<MemTableRep> range_del_table_;
bool is_range_del_table_empty_; std::atomic_bool is_range_del_table_empty_;
// Total data size of all data inserted // Total data size of all data inserted
std::atomic<uint64_t> data_size_; std::atomic<uint64_t> data_size_;

Loading…
Cancel
Save