Rename BlockBasedTable::ReadMetaBlock (#6009)
Summary: According to https://github.com/facebook/rocksdb/wiki/Rocksdb-BlockBasedTable-Format, the block read by BlockBasedTable::ReadMetaBlock is actually the meta index block. Therefore, it is better to rename the function to ReadMetaIndexBlock. This PR also applies some format change to existing code. Pull Request resolved: https://github.com/facebook/rocksdb/pull/6009 Test Plan: make check Differential Revision: D18333238 Pulled By: riversand963 fbshipit-source-id: 2c4340a29b3edba53d19c132cbfd04caf6242aed
This commit is contained in:
parent
230bcae7b6
commit
67e735dbf9
@ -166,7 +166,7 @@ class WriteBatchWithIndex : public WriteBatchBase {
|
|||||||
// called.
|
// called.
|
||||||
Iterator* NewIteratorWithBase(ColumnFamilyHandle* column_family,
|
Iterator* NewIteratorWithBase(ColumnFamilyHandle* column_family,
|
||||||
Iterator* base_iterator,
|
Iterator* base_iterator,
|
||||||
const ReadOptions *opts = nullptr);
|
const ReadOptions* opts = nullptr);
|
||||||
// default column family
|
// default column family
|
||||||
Iterator* NewIteratorWithBase(Iterator* base_iterator);
|
Iterator* NewIteratorWithBase(Iterator* base_iterator);
|
||||||
|
|
||||||
|
@ -1201,28 +1201,29 @@ Status BlockBasedTable::Open(
|
|||||||
rep->compression_dict_handle = BlockHandle::NullBlockHandle();
|
rep->compression_dict_handle = BlockHandle::NullBlockHandle();
|
||||||
|
|
||||||
// Read metaindex
|
// Read metaindex
|
||||||
std::unique_ptr<Block> meta;
|
std::unique_ptr<Block> metaindex;
|
||||||
std::unique_ptr<InternalIterator> meta_iter;
|
std::unique_ptr<InternalIterator> metaindex_iter;
|
||||||
s = new_table->ReadMetaBlock(prefetch_buffer.get(), &meta, &meta_iter);
|
s = new_table->ReadMetaIndexBlock(prefetch_buffer.get(), &metaindex,
|
||||||
|
&metaindex_iter);
|
||||||
if (!s.ok()) {
|
if (!s.ok()) {
|
||||||
return s;
|
return s;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Populates table_properties and some fields that depend on it,
|
// Populates table_properties and some fields that depend on it,
|
||||||
// such as index_type.
|
// such as index_type.
|
||||||
s = new_table->ReadPropertiesBlock(prefetch_buffer.get(), meta_iter.get(),
|
s = new_table->ReadPropertiesBlock(prefetch_buffer.get(),
|
||||||
largest_seqno);
|
metaindex_iter.get(), largest_seqno);
|
||||||
if (!s.ok()) {
|
if (!s.ok()) {
|
||||||
return s;
|
return s;
|
||||||
}
|
}
|
||||||
s = new_table->ReadRangeDelBlock(prefetch_buffer.get(), meta_iter.get(),
|
s = new_table->ReadRangeDelBlock(prefetch_buffer.get(), metaindex_iter.get(),
|
||||||
internal_comparator, &lookup_context);
|
internal_comparator, &lookup_context);
|
||||||
if (!s.ok()) {
|
if (!s.ok()) {
|
||||||
return s;
|
return s;
|
||||||
}
|
}
|
||||||
s = new_table->PrefetchIndexAndFilterBlocks(
|
s = new_table->PrefetchIndexAndFilterBlocks(
|
||||||
prefetch_buffer.get(), meta_iter.get(), new_table.get(), prefetch_all,
|
prefetch_buffer.get(), metaindex_iter.get(), new_table.get(),
|
||||||
table_options, level, &lookup_context);
|
prefetch_all, table_options, level, &lookup_context);
|
||||||
|
|
||||||
if (s.ok()) {
|
if (s.ok()) {
|
||||||
// Update tail prefetch stats
|
// Update tail prefetch stats
|
||||||
@ -1634,17 +1635,19 @@ size_t BlockBasedTable::ApproximateMemoryUsage() const {
|
|||||||
return usage;
|
return usage;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Load the meta-block from the file. On success, return the loaded meta block
|
// Load the meta-index-block from the file. On success, return the loaded
|
||||||
// and its iterator.
|
// metaindex
|
||||||
Status BlockBasedTable::ReadMetaBlock(FilePrefetchBuffer* prefetch_buffer,
|
// block and its iterator.
|
||||||
std::unique_ptr<Block>* meta_block,
|
Status BlockBasedTable::ReadMetaIndexBlock(
|
||||||
std::unique_ptr<InternalIterator>* iter) {
|
FilePrefetchBuffer* prefetch_buffer,
|
||||||
|
std::unique_ptr<Block>* metaindex_block,
|
||||||
|
std::unique_ptr<InternalIterator>* iter) {
|
||||||
// TODO(sanjay): Skip this if footer.metaindex_handle() size indicates
|
// TODO(sanjay): Skip this if footer.metaindex_handle() size indicates
|
||||||
// it is an empty block.
|
// it is an empty block.
|
||||||
std::unique_ptr<Block> meta;
|
std::unique_ptr<Block> metaindex;
|
||||||
Status s = ReadBlockFromFile(
|
Status s = ReadBlockFromFile(
|
||||||
rep_->file.get(), prefetch_buffer, rep_->footer, ReadOptions(),
|
rep_->file.get(), prefetch_buffer, rep_->footer, ReadOptions(),
|
||||||
rep_->footer.metaindex_handle(), &meta, rep_->ioptions,
|
rep_->footer.metaindex_handle(), &metaindex, rep_->ioptions,
|
||||||
true /* decompress */, true /*maybe_compressed*/, BlockType::kMetaIndex,
|
true /* decompress */, true /*maybe_compressed*/, BlockType::kMetaIndex,
|
||||||
UncompressionDict::GetEmptyDict(), rep_->persistent_cache_options,
|
UncompressionDict::GetEmptyDict(), rep_->persistent_cache_options,
|
||||||
kDisableGlobalSequenceNumber, 0 /* read_amp_bytes_per_bit */,
|
kDisableGlobalSequenceNumber, 0 /* read_amp_bytes_per_bit */,
|
||||||
@ -1659,10 +1662,10 @@ Status BlockBasedTable::ReadMetaBlock(FilePrefetchBuffer* prefetch_buffer,
|
|||||||
return s;
|
return s;
|
||||||
}
|
}
|
||||||
|
|
||||||
*meta_block = std::move(meta);
|
*metaindex_block = std::move(metaindex);
|
||||||
// meta block uses bytewise comparator.
|
// meta block uses bytewise comparator.
|
||||||
iter->reset(meta_block->get()->NewDataIterator(BytewiseComparator(),
|
iter->reset(metaindex_block->get()->NewDataIterator(BytewiseComparator(),
|
||||||
BytewiseComparator()));
|
BytewiseComparator()));
|
||||||
return Status::OK();
|
return Status::OK();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -3743,11 +3746,12 @@ Status BlockBasedTable::VerifyChecksum(const ReadOptions& read_options,
|
|||||||
TableReaderCaller caller) {
|
TableReaderCaller caller) {
|
||||||
Status s;
|
Status s;
|
||||||
// Check Meta blocks
|
// Check Meta blocks
|
||||||
std::unique_ptr<Block> meta;
|
std::unique_ptr<Block> metaindex;
|
||||||
std::unique_ptr<InternalIterator> meta_iter;
|
std::unique_ptr<InternalIterator> metaindex_iter;
|
||||||
s = ReadMetaBlock(nullptr /* prefetch buffer */, &meta, &meta_iter);
|
s = ReadMetaIndexBlock(nullptr /* prefetch buffer */, &metaindex,
|
||||||
|
&metaindex_iter);
|
||||||
if (s.ok()) {
|
if (s.ok()) {
|
||||||
s = VerifyChecksumInMetaBlocks(meta_iter.get());
|
s = VerifyChecksumInMetaBlocks(metaindex_iter.get());
|
||||||
if (!s.ok()) {
|
if (!s.ok()) {
|
||||||
return s;
|
return s;
|
||||||
}
|
}
|
||||||
@ -3938,11 +3942,12 @@ Status BlockBasedTable::CreateIndexReader(
|
|||||||
index_reader);
|
index_reader);
|
||||||
}
|
}
|
||||||
case BlockBasedTableOptions::kHashSearch: {
|
case BlockBasedTableOptions::kHashSearch: {
|
||||||
std::unique_ptr<Block> meta_guard;
|
std::unique_ptr<Block> metaindex_guard;
|
||||||
std::unique_ptr<InternalIterator> meta_iter_guard;
|
std::unique_ptr<InternalIterator> metaindex_iter_guard;
|
||||||
auto meta_index_iter = preloaded_meta_index_iter;
|
auto meta_index_iter = preloaded_meta_index_iter;
|
||||||
if (meta_index_iter == nullptr) {
|
if (meta_index_iter == nullptr) {
|
||||||
auto s = ReadMetaBlock(prefetch_buffer, &meta_guard, &meta_iter_guard);
|
auto s = ReadMetaIndexBlock(prefetch_buffer, &metaindex_guard,
|
||||||
|
&metaindex_iter_guard);
|
||||||
if (!s.ok()) {
|
if (!s.ok()) {
|
||||||
// we simply fall back to binary search in case there is any
|
// we simply fall back to binary search in case there is any
|
||||||
// problem with prefix hash index loading.
|
// problem with prefix hash index loading.
|
||||||
@ -3953,7 +3958,7 @@ Status BlockBasedTable::CreateIndexReader(
|
|||||||
use_cache, prefetch, pin,
|
use_cache, prefetch, pin,
|
||||||
lookup_context, index_reader);
|
lookup_context, index_reader);
|
||||||
}
|
}
|
||||||
meta_index_iter = meta_iter_guard.get();
|
meta_index_iter = metaindex_iter_guard.get();
|
||||||
}
|
}
|
||||||
|
|
||||||
return HashIndexReader::Create(this, prefetch_buffer, meta_index_iter,
|
return HashIndexReader::Create(this, prefetch_buffer, meta_index_iter,
|
||||||
@ -4110,31 +4115,33 @@ Status BlockBasedTable::DumpTable(WritableFile* out_file) {
|
|||||||
out_file->Append(
|
out_file->Append(
|
||||||
"Metaindex Details:\n"
|
"Metaindex Details:\n"
|
||||||
"--------------------------------------\n");
|
"--------------------------------------\n");
|
||||||
std::unique_ptr<Block> meta;
|
std::unique_ptr<Block> metaindex;
|
||||||
std::unique_ptr<InternalIterator> meta_iter;
|
std::unique_ptr<InternalIterator> metaindex_iter;
|
||||||
Status s = ReadMetaBlock(nullptr /* prefetch_buffer */, &meta, &meta_iter);
|
Status s = ReadMetaIndexBlock(nullptr /* prefetch_buffer */, &metaindex,
|
||||||
|
&metaindex_iter);
|
||||||
if (s.ok()) {
|
if (s.ok()) {
|
||||||
for (meta_iter->SeekToFirst(); meta_iter->Valid(); meta_iter->Next()) {
|
for (metaindex_iter->SeekToFirst(); metaindex_iter->Valid();
|
||||||
s = meta_iter->status();
|
metaindex_iter->Next()) {
|
||||||
|
s = metaindex_iter->status();
|
||||||
if (!s.ok()) {
|
if (!s.ok()) {
|
||||||
return s;
|
return s;
|
||||||
}
|
}
|
||||||
if (meta_iter->key() == rocksdb::kPropertiesBlock) {
|
if (metaindex_iter->key() == rocksdb::kPropertiesBlock) {
|
||||||
out_file->Append(" Properties block handle: ");
|
out_file->Append(" Properties block handle: ");
|
||||||
out_file->Append(meta_iter->value().ToString(true).c_str());
|
out_file->Append(metaindex_iter->value().ToString(true).c_str());
|
||||||
out_file->Append("\n");
|
out_file->Append("\n");
|
||||||
} else if (meta_iter->key() == rocksdb::kCompressionDictBlock) {
|
} else if (metaindex_iter->key() == rocksdb::kCompressionDictBlock) {
|
||||||
out_file->Append(" Compression dictionary block handle: ");
|
out_file->Append(" Compression dictionary block handle: ");
|
||||||
out_file->Append(meta_iter->value().ToString(true).c_str());
|
out_file->Append(metaindex_iter->value().ToString(true).c_str());
|
||||||
out_file->Append("\n");
|
out_file->Append("\n");
|
||||||
} else if (strstr(meta_iter->key().ToString().c_str(),
|
} else if (strstr(metaindex_iter->key().ToString().c_str(),
|
||||||
"filter.rocksdb.") != nullptr) {
|
"filter.rocksdb.") != nullptr) {
|
||||||
out_file->Append(" Filter block handle: ");
|
out_file->Append(" Filter block handle: ");
|
||||||
out_file->Append(meta_iter->value().ToString(true).c_str());
|
out_file->Append(metaindex_iter->value().ToString(true).c_str());
|
||||||
out_file->Append("\n");
|
out_file->Append("\n");
|
||||||
} else if (meta_iter->key() == rocksdb::kRangeDelBlock) {
|
} else if (metaindex_iter->key() == rocksdb::kRangeDelBlock) {
|
||||||
out_file->Append(" Range deletion block handle: ");
|
out_file->Append(" Range deletion block handle: ");
|
||||||
out_file->Append(meta_iter->value().ToString(true).c_str());
|
out_file->Append(metaindex_iter->value().ToString(true).c_str());
|
||||||
out_file->Append("\n");
|
out_file->Append("\n");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -413,9 +413,9 @@ class BlockBasedTable : public TableReader {
|
|||||||
TailPrefetchStats* tail_prefetch_stats, const bool prefetch_all,
|
TailPrefetchStats* tail_prefetch_stats, const bool prefetch_all,
|
||||||
const bool preload_all,
|
const bool preload_all,
|
||||||
std::unique_ptr<FilePrefetchBuffer>* prefetch_buffer);
|
std::unique_ptr<FilePrefetchBuffer>* prefetch_buffer);
|
||||||
Status ReadMetaBlock(FilePrefetchBuffer* prefetch_buffer,
|
Status ReadMetaIndexBlock(FilePrefetchBuffer* prefetch_buffer,
|
||||||
std::unique_ptr<Block>* meta_block,
|
std::unique_ptr<Block>* metaindex_block,
|
||||||
std::unique_ptr<InternalIterator>* iter);
|
std::unique_ptr<InternalIterator>* iter);
|
||||||
Status TryReadPropertiesWithGlobalSeqno(FilePrefetchBuffer* prefetch_buffer,
|
Status TryReadPropertiesWithGlobalSeqno(FilePrefetchBuffer* prefetch_buffer,
|
||||||
const Slice& handle_value,
|
const Slice& handle_value,
|
||||||
TableProperties** table_properties);
|
TableProperties** table_properties);
|
||||||
|
@ -42,9 +42,8 @@ class BaseDeltaIterator : public Iterator {
|
|||||||
base_iterator_(base_iterator),
|
base_iterator_(base_iterator),
|
||||||
delta_iterator_(delta_iterator),
|
delta_iterator_(delta_iterator),
|
||||||
comparator_(comparator),
|
comparator_(comparator),
|
||||||
iterate_upper_bound_(read_options? read_options->iterate_upper_bound :
|
iterate_upper_bound_(read_options ? read_options->iterate_upper_bound
|
||||||
nullptr)
|
: nullptr) {}
|
||||||
{}
|
|
||||||
|
|
||||||
~BaseDeltaIterator() override {}
|
~BaseDeltaIterator() override {}
|
||||||
|
|
||||||
@ -284,8 +283,8 @@ class BaseDeltaIterator : public Iterator {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if (iterate_upper_bound_) {
|
if (iterate_upper_bound_) {
|
||||||
if (comparator_->Compare(delta_entry.key,
|
if (comparator_->Compare(delta_entry.key, *iterate_upper_bound_) >=
|
||||||
*iterate_upper_bound_) >= 0) {
|
0) {
|
||||||
// out of upper bound -> finished.
|
// out of upper bound -> finished.
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -660,7 +659,7 @@ WBWIIterator* WriteBatchWithIndex::NewIterator(
|
|||||||
|
|
||||||
Iterator* WriteBatchWithIndex::NewIteratorWithBase(
|
Iterator* WriteBatchWithIndex::NewIteratorWithBase(
|
||||||
ColumnFamilyHandle* column_family, Iterator* base_iterator,
|
ColumnFamilyHandle* column_family, Iterator* base_iterator,
|
||||||
const ReadOptions *read_options) {
|
const ReadOptions* read_options) {
|
||||||
if (rep->overwrite_key == false) {
|
if (rep->overwrite_key == false) {
|
||||||
assert(false);
|
assert(false);
|
||||||
return nullptr;
|
return nullptr;
|
||||||
|
Loading…
Reference in New Issue
Block a user