|
|
|
@ -25,12 +25,14 @@ |
|
|
|
|
#include "rocksdb/universal_compaction.h" |
|
|
|
|
#include "rocksdb/statistics.h" |
|
|
|
|
#include "rocksdb/slice_transform.h" |
|
|
|
|
#include "rocksdb/table.h" |
|
|
|
|
|
|
|
|
|
using rocksdb::Cache; |
|
|
|
|
using rocksdb::Comparator; |
|
|
|
|
using rocksdb::CompressionType; |
|
|
|
|
using rocksdb::DB; |
|
|
|
|
using rocksdb::Env; |
|
|
|
|
using rocksdb::InfoLogLevel; |
|
|
|
|
using rocksdb::FileLock; |
|
|
|
|
using rocksdb::FilterPolicy; |
|
|
|
|
using rocksdb::FlushOptions; |
|
|
|
@ -656,6 +658,11 @@ void rocksdb_options_set_info_log(rocksdb_options_t* opt, rocksdb_logger_t* l) { |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
void rocksdb_options_set_info_log_level( |
|
|
|
|
rocksdb_options_t* opt, int v) { |
|
|
|
|
opt->rep.info_log_level = static_cast<InfoLogLevel>(v); |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
void rocksdb_options_set_write_buffer_size(rocksdb_options_t* opt, size_t s) { |
|
|
|
|
opt->rep.write_buffer_size = s; |
|
|
|
|
} |
|
|
|
@ -714,6 +721,14 @@ void rocksdb_options_set_max_grandparent_overlap_factor( |
|
|
|
|
opt->rep.max_grandparent_overlap_factor = n; |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
void rocksdb_options_set_max_bytes_for_level_multiplier_additional( |
|
|
|
|
rocksdb_options_t* opt, int* level_values, size_t num_levels) { |
|
|
|
|
opt->rep.max_bytes_for_level_multiplier_additional.resize(num_levels); |
|
|
|
|
for (size_t i = 0; i < num_levels; ++i) { |
|
|
|
|
opt->rep.max_bytes_for_level_multiplier_additional[i] = level_values[i]; |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
void rocksdb_options_enable_statistics(rocksdb_options_t* opt) { |
|
|
|
|
opt->rep.statistics = rocksdb::CreateDBStatistics(); |
|
|
|
|
} |
|
|
|
@ -857,6 +872,24 @@ void rocksdb_options_set_advise_random_on_open( |
|
|
|
|
opt->rep.advise_random_on_open = v; |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
void rocksdb_options_set_access_hint_on_compaction_start( |
|
|
|
|
rocksdb_options_t* opt, int v) { |
|
|
|
|
switch(v) { |
|
|
|
|
case 0: |
|
|
|
|
opt->rep.access_hint_on_compaction_start = rocksdb::Options::NONE; |
|
|
|
|
break; |
|
|
|
|
case 1: |
|
|
|
|
opt->rep.access_hint_on_compaction_start = rocksdb::Options::NORMAL; |
|
|
|
|
break; |
|
|
|
|
case 2: |
|
|
|
|
opt->rep.access_hint_on_compaction_start = rocksdb::Options::SEQUENTIAL; |
|
|
|
|
break; |
|
|
|
|
case 3: |
|
|
|
|
opt->rep.access_hint_on_compaction_start = rocksdb::Options::WILLNEED; |
|
|
|
|
break; |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
void rocksdb_options_set_use_adaptive_mutex( |
|
|
|
|
rocksdb_options_t* opt, unsigned char v) { |
|
|
|
|
opt->rep.use_adaptive_mutex = v; |
|
|
|
@ -867,6 +900,11 @@ void rocksdb_options_set_bytes_per_sync( |
|
|
|
|
opt->rep.bytes_per_sync = v; |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
void rocksdb_options_set_verify_checksums_in_compaction( |
|
|
|
|
rocksdb_options_t* opt, unsigned char v) { |
|
|
|
|
opt->rep.verify_checksums_in_compaction = v; |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
void rocksdb_options_set_filter_deletes( |
|
|
|
|
rocksdb_options_t* opt, unsigned char v) { |
|
|
|
|
opt->rep.filter_deletes = v; |
|
|
|
@ -1003,11 +1041,48 @@ void rocksdb_options_set_hash_link_list_rep( |
|
|
|
|
opt->rep.memtable_factory.reset(factory); |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
void rocksdb_options_set_plain_table_factory( |
|
|
|
|
rocksdb_options_t *opt, uint32_t user_key_len, int bloom_bits_per_key, |
|
|
|
|
double hash_table_ratio, size_t index_sparseness) { |
|
|
|
|
static rocksdb::TableFactory* factory = 0; |
|
|
|
|
if (!factory) { |
|
|
|
|
factory = rocksdb::NewPlainTableFactory( |
|
|
|
|
user_key_len, bloom_bits_per_key, |
|
|
|
|
hash_table_ratio, index_sparseness); |
|
|
|
|
} |
|
|
|
|
opt->rep.table_factory.reset(factory); |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
void rocksdb_options_set_max_successive_merges( |
|
|
|
|
rocksdb_options_t* opt, size_t v) { |
|
|
|
|
opt->rep.max_successive_merges = v; |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
void rocksdb_options_set_min_partial_merge_operands( |
|
|
|
|
rocksdb_options_t* opt, uint32_t v) { |
|
|
|
|
opt->rep.min_partial_merge_operands = v; |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
void rocksdb_options_set_bloom_locality( |
|
|
|
|
rocksdb_options_t* opt, uint32_t v) { |
|
|
|
|
opt->rep.bloom_locality = v; |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
void rocksdb_options_set_allow_thread_local( |
|
|
|
|
rocksdb_options_t* opt, unsigned char v) { |
|
|
|
|
opt->rep.allow_thread_local = v; |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
void rocksdb_options_set_inplace_update_support( |
|
|
|
|
rocksdb_options_t* opt, unsigned char v) { |
|
|
|
|
opt->rep.inplace_update_support = v; |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
void rocksdb_options_set_inplace_update_num_locks( |
|
|
|
|
rocksdb_options_t* opt, size_t v) { |
|
|
|
|
opt->rep.inplace_update_num_locks = v; |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
void rocksdb_options_set_compaction_style(rocksdb_options_t *opt, int style) { |
|
|
|
|
opt->rep.compaction_style = static_cast<rocksdb::CompactionStyle>(style); |
|
|
|
|
} |
|
|
|
@ -1022,21 +1097,14 @@ DB::OpenForReadOnly |
|
|
|
|
DB::MultiGet |
|
|
|
|
DB::KeyMayExist |
|
|
|
|
DB::GetOptions |
|
|
|
|
DB::GetLiveFiles |
|
|
|
|
DB::GetSortedWalFiles |
|
|
|
|
DB::GetLatestSequenceNumber |
|
|
|
|
DB::GetUpdatesSince |
|
|
|
|
DB::DeleteFile |
|
|
|
|
DB::GetDbIdentity |
|
|
|
|
DB::RunManualCompaction |
|
|
|
|
custom cache |
|
|
|
|
compaction_filter |
|
|
|
|
max_bytes_for_level_multiplier_additional |
|
|
|
|
access_hint_on_compaction_start |
|
|
|
|
table_factory |
|
|
|
|
table_properties_collectors |
|
|
|
|
inplace_update_support |
|
|
|
|
inplace_update_num_locks |
|
|
|
|
*/ |
|
|
|
|
|
|
|
|
|
rocksdb_comparator_t* rocksdb_comparator_create( |
|
|
|
|