2016-02-09 15:12:00 -08:00
|
|
|
// Copyright (c) 2011-present, Facebook, Inc. All rights reserved.
|
Add OptionsUtil::LoadOptionsFromFile() API
Summary:
This patch adds OptionsUtil::LoadOptionsFromFile() and
OptionsUtil::LoadLatestOptionsFromDB(), which allow developers
to construct DBOptions and ColumnFamilyOptions from a RocksDB
options file. Note that most pointer-typed options such as
merge_operator will not be constructed.
With this API, developers no longer need to remember all the
options in order to reopen an existing rocksdb instance like
the following:
DBOptions db_options;
std::vector<std::string> cf_names;
std::vector<ColumnFamilyOptions> cf_opts;
// Load primitive-typed options from an existing DB
OptionsUtil::LoadLatestOptionsFromDB(
dbname, &db_options, &cf_names, &cf_opts);
// Initialize necessary pointer-typed options
cf_opts[0].merge_operator.reset(new MyMergeOperator());
...
// Construct the vector of ColumnFamilyDescriptor
std::vector<ColumnFamilyDescriptor> cf_descs;
for (size_t i = 0; i < cf_opts.size(); ++i) {
cf_descs.emplace_back(cf_names[i], cf_opts[i]);
}
// Open the DB
DB* db = nullptr;
std::vector<ColumnFamilyHandle*> cf_handles;
auto s = DB::Open(db_options, dbname, cf_descs,
&handles, &db);
Test Plan:
Augment existing tests in column_family_test
options_test
db_test
Reviewers: igor, IslamAbdelRahman, sdong, anthony
Reviewed By: anthony
Subscribers: dhruba, leveldb
Differential Revision: https://reviews.facebook.net/D49095
2015-11-12 06:52:43 -08:00
|
|
|
// This source code is licensed under the BSD-style license found in the
|
|
|
|
// LICENSE file in the root directory of this source tree. An additional grant
|
|
|
|
// of patent rights can be found in the PATENTS file in the same directory.
|
|
|
|
//
|
|
|
|
// This file demonstrates how to use the utility functions defined in
|
|
|
|
// rocksdb/utilities/options_util.h to open a rocksdb database without
|
|
|
|
// remembering all the rocksdb options.
|
|
|
|
#include <cstdio>
|
|
|
|
#include <string>
|
|
|
|
#include <vector>
|
|
|
|
|
|
|
|
#include "rocksdb/cache.h"
|
|
|
|
#include "rocksdb/compaction_filter.h"
|
|
|
|
#include "rocksdb/db.h"
|
|
|
|
#include "rocksdb/options.h"
|
|
|
|
#include "rocksdb/slice.h"
|
|
|
|
#include "rocksdb/table.h"
|
|
|
|
#include "rocksdb/utilities/options_util.h"
|
|
|
|
|
|
|
|
using namespace rocksdb;
|
|
|
|
|
|
|
|
std::string kDBPath = "/tmp/rocksdb_options_file_example";
|
|
|
|
|
|
|
|
namespace {
|
|
|
|
// A dummy compaction filter
|
|
|
|
class DummyCompactionFilter : public CompactionFilter {
|
|
|
|
public:
|
|
|
|
virtual ~DummyCompactionFilter() {}
|
|
|
|
virtual bool Filter(int level, const Slice& key, const Slice& existing_value,
|
|
|
|
std::string* new_value, bool* value_changed) const {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
virtual const char* Name() const { return "DummyCompactionFilter"; }
|
|
|
|
};
|
|
|
|
|
|
|
|
} // namespace
|
|
|
|
|
|
|
|
int main() {
|
|
|
|
DBOptions db_opt;
|
|
|
|
db_opt.create_if_missing = true;
|
|
|
|
|
|
|
|
std::vector<ColumnFamilyDescriptor> cf_descs;
|
|
|
|
cf_descs.push_back({kDefaultColumnFamilyName, ColumnFamilyOptions()});
|
|
|
|
cf_descs.push_back({"new_cf", ColumnFamilyOptions()});
|
|
|
|
|
|
|
|
// initialize BlockBasedTableOptions
|
|
|
|
auto cache = NewLRUCache(1 * 1024 * 1024 * 1024);
|
|
|
|
BlockBasedTableOptions bbt_opts;
|
|
|
|
bbt_opts.block_size = 32 * 1024;
|
|
|
|
bbt_opts.block_cache = cache;
|
|
|
|
|
|
|
|
// initialize column families options
|
|
|
|
std::unique_ptr<CompactionFilter> compaction_filter;
|
|
|
|
compaction_filter.reset(new DummyCompactionFilter());
|
|
|
|
cf_descs[0].options.table_factory.reset(NewBlockBasedTableFactory(bbt_opts));
|
|
|
|
cf_descs[0].options.compaction_filter = compaction_filter.get();
|
|
|
|
cf_descs[1].options.table_factory.reset(NewBlockBasedTableFactory(bbt_opts));
|
|
|
|
|
|
|
|
// destroy and open DB
|
|
|
|
DB* db;
|
|
|
|
Status s = DestroyDB(kDBPath, Options(db_opt, cf_descs[0].options));
|
|
|
|
assert(s.ok());
|
|
|
|
s = DB::Open(Options(db_opt, cf_descs[0].options), kDBPath, &db);
|
|
|
|
assert(s.ok());
|
|
|
|
|
|
|
|
// Create column family, and rocksdb will persist the options.
|
|
|
|
ColumnFamilyHandle* cf;
|
|
|
|
s = db->CreateColumnFamily(ColumnFamilyOptions(), "new_cf", &cf);
|
|
|
|
assert(s.ok());
|
|
|
|
|
|
|
|
// close DB
|
|
|
|
delete cf;
|
|
|
|
delete db;
|
|
|
|
|
|
|
|
// In the following code, we will reopen the rocksdb instance using
|
|
|
|
// the options file stored in the db directory.
|
|
|
|
|
|
|
|
// Load the options file.
|
|
|
|
DBOptions loaded_db_opt;
|
|
|
|
std::vector<ColumnFamilyDescriptor> loaded_cf_descs;
|
|
|
|
s = LoadLatestOptions(kDBPath, Env::Default(), &loaded_db_opt,
|
|
|
|
&loaded_cf_descs);
|
|
|
|
assert(s.ok());
|
|
|
|
assert(loaded_db_opt.create_if_missing == db_opt.create_if_missing);
|
|
|
|
|
|
|
|
// Initialize pointer options for each column family
|
|
|
|
for (size_t i = 0; i < loaded_cf_descs.size(); ++i) {
|
|
|
|
auto* loaded_bbt_opt = reinterpret_cast<BlockBasedTableOptions*>(
|
|
|
|
loaded_cf_descs[0].options.table_factory->GetOptions());
|
|
|
|
// Expect the same as BlockBasedTableOptions will be loaded form file.
|
|
|
|
assert(loaded_bbt_opt->block_size == bbt_opts.block_size);
|
|
|
|
// However, block_cache needs to be manually initialized as documented
|
|
|
|
// in rocksdb/utilities/options_util.h.
|
|
|
|
loaded_bbt_opt->block_cache = cache;
|
|
|
|
}
|
|
|
|
// In addition, as pointer options are initialized with default value,
|
|
|
|
// we need to properly initialized all the pointer options if non-defalut
|
|
|
|
// values are used before calling DB::Open().
|
|
|
|
assert(loaded_cf_descs[0].options.compaction_filter == nullptr);
|
|
|
|
loaded_cf_descs[0].options.compaction_filter = compaction_filter.get();
|
|
|
|
|
|
|
|
// reopen the db using the loaded options.
|
|
|
|
std::vector<ColumnFamilyHandle*> handles;
|
|
|
|
s = DB::Open(loaded_db_opt, kDBPath, loaded_cf_descs, &handles, &db);
|
|
|
|
assert(s.ok());
|
|
|
|
|
|
|
|
// close DB
|
|
|
|
for (auto* handle : handles) {
|
|
|
|
delete handle;
|
|
|
|
}
|
|
|
|
delete db;
|
|
|
|
}
|