Improve Options sanitization and add MmapReadRequired() to TableFactory

Summary:
Currently, PlainTable must use mmap_reads.  When PlainTable is used but
allow_mmap_reads is not set, rocksdb will fail in flush.

This diff improve Options sanitization and add MmapReadRequired() to
TableFactory.

Test Plan:
export ROCKSDB_TESTS=PlainTableOptionsSanitizeTest
make db_test -j32
./db_test

Reviewers: sdong, ljin

Reviewed By: ljin

Subscribers: you, leveldb

Differential Revision: https://reviews.facebook.net/D21939
main
Yueh-Hsuan Chiang 11 years ago
parent e173bf9c19
commit 63a2215c63
  1. 19
      db/db_impl.cc
  2. 12
      db/db_test.cc
  3. 6
      include/rocksdb/table.h
  4. 10
      table/adaptive_table_factory.h
  5. 5
      table/block_based_table_factory.h
  6. 5
      table/cuckoo_table_factory.h
  7. 9
      table/plain_table_factory.h

@ -291,6 +291,19 @@ DBOptions SanitizeOptions(const std::string& dbname, const DBOptions& src) {
return result; return result;
} }
Status SanitizeDBOptionsByCFOptions(
DBOptions* db_opts,
const std::vector<ColumnFamilyDescriptor>& column_families) {
Status s;
for (auto cf : column_families) {
s = cf.options.table_factory->SanitizeDBOptions(db_opts);
if (!s.ok()) {
return s;
}
}
return Status::OK();
}
namespace { namespace {
CompressionType GetCompressionFlush(const Options& options) { CompressionType GetCompressionFlush(const Options& options) {
// Compressing memtable flushes might not help unless the sequential load // Compressing memtable flushes might not help unless the sequential load
@ -4743,7 +4756,11 @@ Status DB::Open(const Options& options, const std::string& dbname, DB** dbptr) {
column_families.push_back( column_families.push_back(
ColumnFamilyDescriptor(kDefaultColumnFamilyName, cf_options)); ColumnFamilyDescriptor(kDefaultColumnFamilyName, cf_options));
std::vector<ColumnFamilyHandle*> handles; std::vector<ColumnFamilyHandle*> handles;
Status s = DB::Open(db_options, dbname, column_families, &handles, dbptr); Status s = SanitizeDBOptionsByCFOptions(&db_options, column_families);
if (!s.ok()) {
return s;
}
s = DB::Open(db_options, dbname, column_families, &handles, dbptr);
if (s.ok()) { if (s.ok()) {
assert(handles.size() == 1); assert(handles.size() == 1);
// i can delete the handle since DBImpl is always holding a reference to // i can delete the handle since DBImpl is always holding a reference to

@ -7679,6 +7679,18 @@ TEST(DBTest, RateLimitingTest) {
ASSERT_TRUE(ratio < 0.6); ASSERT_TRUE(ratio < 0.6);
} }
TEST(DBTest, TableOptionsSanitizeTest) {
Options options = CurrentOptions();
options.create_if_missing = true;
DestroyAndReopen(&options);
ASSERT_EQ(db_->GetOptions().allow_mmap_reads, false);
options.table_factory.reset(new PlainTableFactory());
options.prefix_extractor.reset(NewNoopTransform());
Destroy(&options);
ASSERT_TRUE(TryReopen(&options).IsNotSupported());
}
} // namespace rocksdb } // namespace rocksdb
int main(int argc, char** argv) { int main(int argc, char** argv) {

@ -253,6 +253,12 @@ class TableFactory {
virtual TableBuilder* NewTableBuilder( virtual TableBuilder* NewTableBuilder(
const Options& options, const InternalKeyComparator& internal_comparator, const Options& options, const InternalKeyComparator& internal_comparator,
WritableFile* file, CompressionType compression_type) const = 0; WritableFile* file, CompressionType compression_type) const = 0;
// Sanitizes the specified DB Options.
//
// If the function cannot find a way to sanitize the input DB Options,
// a non-ok Status will be returned.
virtual Status SanitizeDBOptions(DBOptions* db_opts) const = 0;
}; };
#ifndef ROCKSDB_LITE #ifndef ROCKSDB_LITE

@ -41,6 +41,16 @@ class AdaptiveTableFactory : public TableFactory {
CompressionType compression_type) const CompressionType compression_type) const
override; override;
// Sanitizes the specified DB Options.
Status SanitizeDBOptions(DBOptions* db_opts) const override {
if (db_opts->allow_mmap_reads == false) {
return Status::NotSupported(
"AdaptiveTable with allow_mmap_reads == false is not supported.");
}
return Status::OK();
}
private: private:
std::shared_ptr<TableFactory> table_factory_to_write_; std::shared_ptr<TableFactory> table_factory_to_write_;
std::shared_ptr<TableFactory> block_based_table_factory_; std::shared_ptr<TableFactory> block_based_table_factory_;

@ -43,6 +43,11 @@ class BlockBasedTableFactory : public TableFactory {
const Options& options, const InternalKeyComparator& internal_comparator, const Options& options, const InternalKeyComparator& internal_comparator,
WritableFile* file, CompressionType compression_type) const override; WritableFile* file, CompressionType compression_type) const override;
// Sanitizes the specified DB Options.
Status SanitizeDBOptions(DBOptions* db_opts) const override {
return Status::OK();
}
private: private:
BlockBasedTableOptions table_options_; BlockBasedTableOptions table_options_;
}; };

@ -40,6 +40,11 @@ class CuckooTableFactory : public TableFactory {
const InternalKeyComparator& icomparator, WritableFile* file, const InternalKeyComparator& icomparator, WritableFile* file,
CompressionType compression_type) const override; CompressionType compression_type) const override;
// Sanitizes the specified DB Options.
Status SanitizeDBOptions(DBOptions* db_opts) const override {
return Status::OK();
}
private: private:
const double hash_table_ratio_; const double hash_table_ratio_;
const uint32_t max_search_depth_; const uint32_t max_search_depth_;

@ -166,6 +166,15 @@ class PlainTableFactory : public TableFactory {
static const char kValueTypeSeqId0 = 0xFF; static const char kValueTypeSeqId0 = 0xFF;
// Sanitizes the specified DB Options.
Status SanitizeDBOptions(DBOptions* db_opts) const override {
if (db_opts->allow_mmap_reads == false) {
return Status::NotSupported(
"PlainTable with allow_mmap_reads == false is not supported.");
}
return Status::OK();
}
private: private:
uint32_t user_key_len_; uint32_t user_key_len_;
int bloom_bits_per_key_; int bloom_bits_per_key_;

Loading…
Cancel
Save