Skip to content

Commit

Permalink
Make BlockBasedTableIterator compaction-aware (facebook#4048)
Browse files Browse the repository at this point in the history
Summary:
Pass in `for_compaction` to `BlockBasedTableIterator` via `BlockBasedTableReader::NewIterator`.

In 7103559, `for_compaction` was set in `BlockBasedTable::Rep` via `BlockBasedTable::SetupForCompaction`. In hindsight it was not the right decision; it also caused TSAN to complain.
Closes facebook#4048

Differential Revision: D8601056

Pulled By: sagar0

fbshipit-source-id: 30127e898c15c38c1080d57710b8c5a6d64a0ab3
  • Loading branch information
sagar0 authored and facebook-github-bot committed Jun 25, 2018
1 parent a71e467 commit 189f0c2
Show file tree
Hide file tree
Showing 10 changed files with 25 additions and 17 deletions.
2 changes: 1 addition & 1 deletion db/table_cache.cc
Original file line number Diff line number Diff line change
Expand Up @@ -236,7 +236,7 @@ InternalIterator* TableCache::NewIterator(
result = NewEmptyInternalIterator(arena);
} else {
result = table_reader->NewIterator(options, prefix_extractor, arena,
skip_filters);
skip_filters, for_compaction);
}
if (create_new_table_reader) {
assert(handle == nullptr);
Expand Down
11 changes: 6 additions & 5 deletions table/block_based_table_reader.cc
Original file line number Diff line number Diff line change
Expand Up @@ -1028,7 +1028,6 @@ void BlockBasedTable::SetupForCompaction() {
default:
assert(false);
}
rep_->for_compaction = true;
}

std::shared_ptr<const TableProperties> BlockBasedTable::GetTableProperties()
Expand Down Expand Up @@ -2004,7 +2003,7 @@ void BlockBasedTableIterator::InitDataBlock() {
// Automatically prefetch additional data when a range scan (iterator) does
// more than 2 sequential IOs. This is enabled only for user reads and when
// ReadOptions.readahead_size is 0.
if (!rep->for_compaction && read_options_.readahead_size == 0) {
if (!for_compaction_ && read_options_.readahead_size == 0) {
num_file_reads_++;
if (num_file_reads_ > 2) {
if (!rep->file->use_direct_io() &&
Expand Down Expand Up @@ -2101,7 +2100,7 @@ void BlockBasedTableIterator::FindKeyBackward() {

InternalIterator* BlockBasedTable::NewIterator(
const ReadOptions& read_options, const SliceTransform* prefix_extractor,
Arena* arena, bool skip_filters) {
Arena* arena, bool skip_filters, bool for_compaction) {
bool prefix_extractor_changed =
PrefixExtractorChanged(rep_->table_properties.get(), prefix_extractor);
const bool kIsNotIndex = false;
Expand All @@ -2114,15 +2113,17 @@ InternalIterator* BlockBasedTable::NewIterator(
rep_->index_type == BlockBasedTableOptions::kHashSearch),
!skip_filters && !read_options.total_order_seek &&
prefix_extractor != nullptr && !prefix_extractor_changed,
prefix_extractor, kIsNotIndex);
prefix_extractor, kIsNotIndex, true /*key_includes_seq*/,
for_compaction);
} else {
auto* mem = arena->AllocateAligned(sizeof(BlockBasedTableIterator));
return new (mem) BlockBasedTableIterator(
this, read_options, rep_->internal_comparator,
NewIndexIterator(read_options, prefix_extractor_changed),
!skip_filters && !read_options.total_order_seek &&
prefix_extractor != nullptr && !prefix_extractor_changed,
prefix_extractor, kIsNotIndex);
prefix_extractor, kIsNotIndex, true /*key_includes_seq*/,
for_compaction);
}
}

Expand Down
11 changes: 7 additions & 4 deletions table/block_based_table_reader.h
Original file line number Diff line number Diff line change
Expand Up @@ -104,7 +104,8 @@ class BlockBasedTable : public TableReader {
InternalIterator* NewIterator(const ReadOptions&,
const SliceTransform* prefix_extractor,
Arena* arena = nullptr,
bool skip_filters = false) override;
bool skip_filters = false,
bool for_compaction = false) override;

InternalIterator* NewRangeTombstoneIterator(
const ReadOptions& read_options) override;
Expand Down Expand Up @@ -506,8 +507,6 @@ struct BlockBasedTable::Rep {
bool blocks_maybe_compressed = true;

bool closed = false;

bool for_compaction = false;
};

class BlockBasedTableIterator : public InternalIterator {
Expand All @@ -517,7 +516,8 @@ class BlockBasedTableIterator : public InternalIterator {
const InternalKeyComparator& icomp,
InternalIterator* index_iter, bool check_filter,
const SliceTransform* prefix_extractor, bool is_index,
bool key_includes_seq = true)
bool key_includes_seq = true,
bool for_compaction = false)
: table_(table),
read_options_(read_options),
icomp_(icomp),
Expand All @@ -527,6 +527,7 @@ class BlockBasedTableIterator : public InternalIterator {
check_filter_(check_filter),
is_index_(is_index),
key_includes_seq_(key_includes_seq),
for_compaction_(for_compaction),
prefix_extractor_(prefix_extractor) {}

~BlockBasedTableIterator() { delete index_iter_; }
Expand Down Expand Up @@ -624,6 +625,8 @@ class BlockBasedTableIterator : public InternalIterator {
bool is_index_;
// If the keys in the blocks over which we iterate include 8 byte sequence
bool key_includes_seq_;
// If this iterator is created for compaction
bool for_compaction_;
// TODO use block offset instead
std::string prev_index_value_;
const SliceTransform* prefix_extractor_;
Expand Down
2 changes: 1 addition & 1 deletion table/cuckoo_table_reader.cc
Original file line number Diff line number Diff line change
Expand Up @@ -380,7 +380,7 @@ extern InternalIterator* NewErrorInternalIterator(const Status& status,
InternalIterator* CuckooTableReader::NewIterator(
const ReadOptions& /*read_options*/,
const SliceTransform* /* prefix_extractor */, Arena* arena,
bool /*skip_filters*/) {
bool /*skip_filters*/, bool /*for_compaction*/) {
if (!status().ok()) {
return NewErrorInternalIterator(
Status::Corruption("CuckooTableReader status is not okay."), arena);
Expand Down
3 changes: 2 additions & 1 deletion table/cuckoo_table_reader.h
Original file line number Diff line number Diff line change
Expand Up @@ -49,7 +49,8 @@ class CuckooTableReader: public TableReader {
InternalIterator* NewIterator(const ReadOptions&,
const SliceTransform* prefix_extractor,
Arena* arena = nullptr,
bool skip_filters = false) override;
bool skip_filters = false,
bool for_compaction = false) override;
void Prepare(const Slice& target) override;

// Report an approximation of how much memory has been used.
Expand Down
2 changes: 1 addition & 1 deletion table/mock_table.cc
Original file line number Diff line number Diff line change
Expand Up @@ -28,7 +28,7 @@ stl_wrappers::KVMap MakeMockFile(

InternalIterator* MockTableReader::NewIterator(
const ReadOptions&, const SliceTransform* /* prefix_extractor */,
Arena* /*arena*/, bool /*skip_filters*/) {
Arena* /*arena*/, bool /*skip_filters*/, bool /*for_compaction*/) {
return new MockTableIterator(table_);
}

Expand Down
3 changes: 2 additions & 1 deletion table/mock_table.h
Original file line number Diff line number Diff line change
Expand Up @@ -41,7 +41,8 @@ class MockTableReader : public TableReader {
InternalIterator* NewIterator(const ReadOptions&,
const SliceTransform* prefix_extractor,
Arena* arena = nullptr,
bool skip_filters = false) override;
bool skip_filters = false,
bool for_compaction = false) override;

Status Get(const ReadOptions& readOptions, const Slice& key,
GetContext* get_context, const SliceTransform* prefix_extractor,
Expand Down
2 changes: 1 addition & 1 deletion table/plain_table_reader.cc
Original file line number Diff line number Diff line change
Expand Up @@ -191,7 +191,7 @@ void PlainTableReader::SetupForCompaction() {

InternalIterator* PlainTableReader::NewIterator(
const ReadOptions& options, const SliceTransform* /* prefix_extractor */,
Arena* arena, bool /*skip_filters*/) {
Arena* arena, bool /*skip_filters*/, bool /*for_compaction*/) {
bool use_prefix_seek = !IsTotalOrderMode() && !options.total_order_seek;
if (arena == nullptr) {
return new PlainTableIterator(this, use_prefix_seek);
Expand Down
3 changes: 2 additions & 1 deletion table/plain_table_reader.h
Original file line number Diff line number Diff line change
Expand Up @@ -82,7 +82,8 @@ class PlainTableReader: public TableReader {
InternalIterator* NewIterator(const ReadOptions&,
const SliceTransform* prefix_extractor,
Arena* arena = nullptr,
bool skip_filters = false) override;
bool skip_filters = false,
bool for_compaction = false) override;

void Prepare(const Slice& target) override;

Expand Down
3 changes: 2 additions & 1 deletion table/table_reader.h
Original file line number Diff line number Diff line change
Expand Up @@ -42,7 +42,8 @@ class TableReader {
virtual InternalIterator* NewIterator(const ReadOptions&,
const SliceTransform* prefix_extractor,
Arena* arena = nullptr,
bool skip_filters = false) = 0;
bool skip_filters = false,
bool for_compaction = false) = 0;

virtual InternalIterator* NewRangeTombstoneIterator(
const ReadOptions& /*read_options*/) {
Expand Down

0 comments on commit 189f0c2

Please sign in to comment.