From d2ab67a041d520301919e326bc58bf5ea01ac953 Mon Sep 17 00:00:00 2001 From: quake Date: Thu, 28 Sep 2023 21:13:07 +0900 Subject: [PATCH 1/2] performance: tuning rocksdb bloom filter --- db/src/db.rs | 48 ++++++++++++++++++++++++++++++------- resource/ckb.toml | 6 ++--- resource/default.db-options | 4 ---- 3 files changed, 43 insertions(+), 15 deletions(-) diff --git a/db/src/db.rs b/db/src/db.rs index 306d85c74a..34f7e3f47d 100644 --- a/db/src/db.rs +++ b/db/src/db.rs @@ -11,8 +11,9 @@ use rocksdb::ops::{ Put, SetOptions, WriteOps, }; use rocksdb::{ - ffi, ColumnFamily, ColumnFamilyDescriptor, DBPinnableSlice, FullOptions, IteratorMode, - OptimisticTransactionDB, OptimisticTransactionOptions, Options, WriteBatch, WriteOptions, + ffi, BlockBasedIndexType, BlockBasedOptions, Cache, ColumnFamily, ColumnFamilyDescriptor, + DBPinnableSlice, FullOptions, IteratorMode, OptimisticTransactionDB, + OptimisticTransactionOptions, Options, SliceTransform, WriteBatch, WriteOptions, }; use std::path::Path; use std::sync::Arc; @@ -25,20 +26,28 @@ pub struct RocksDB { pub(crate) inner: Arc, } -const DEFAULT_CACHE_SIZE: usize = 128 << 20; +const DEFAULT_CACHE_SIZE: usize = 256 << 20; +const DEFAULT_CACHE_ENTRY_CHARGE_SIZE: usize = 4096; impl RocksDB { pub(crate) fn open_with_check(config: &DBConfig, columns: u32) -> Result { let cf_names: Vec<_> = (0..columns).map(|c| c.to_string()).collect(); + let mut cache = None; - let (mut opts, cf_descriptors) = if let Some(ref file) = config.options_file { - let cache_size = match config.cache_size { + let (mut opts, mut cf_descriptors) = if let Some(ref file) = config.options_file { + cache = match config.cache_size { Some(0) => None, - Some(size) => Some(size), - None => Some(DEFAULT_CACHE_SIZE), + Some(size) => Some(Cache::new_hyper_clock_cache( + size, + DEFAULT_CACHE_ENTRY_CHARGE_SIZE, + )), + None => Some(Cache::new_hyper_clock_cache( + DEFAULT_CACHE_SIZE, + DEFAULT_CACHE_ENTRY_CHARGE_SIZE, + )), }; - let mut full_opts = FullOptions::load_from_file(file, cache_size, false) + let mut full_opts = FullOptions::load_from_file_with_cache(file, cache.clone(), false) .map_err(|err| internal_error(format!("failed to load the options file: {err}")))?; let cf_names_str: Vec<&str> = cf_names.iter().map(|s| s.as_str()).collect(); full_opts @@ -60,8 +69,31 @@ impl RocksDB { (opts, cf_descriptors) }; + for cf in cf_descriptors.iter_mut() { + let mut block_opts = BlockBasedOptions::default(); + block_opts.set_ribbon_filter(10.0); + block_opts.set_cache_index_and_filter_blocks(true); + block_opts.set_pin_l0_filter_and_index_blocks_in_cache(true); + block_opts.set_index_type(BlockBasedIndexType::TwoLevelIndexSearch); + block_opts.set_partition_filters(true); + block_opts.set_metadata_block_size(4096); + block_opts.set_pin_top_level_index_and_filter(true); + match cache { + Some(ref cache) => block_opts.set_block_cache(cache), + None => block_opts.disable_cache(), + } + // only COLUMN_BLOCK_BODY column family use prefix seek + if cf.name() == "2" { + block_opts.set_whole_key_filtering(false); + cf.options + .set_prefix_extractor(SliceTransform::create_fixed_prefix(32)); + } + cf.options.set_block_based_table_factory(&block_opts); + } + opts.create_if_missing(true); opts.create_missing_column_families(true); + opts.enable_statistics(); let db = OptimisticTransactionDB::open_cf_descriptors(&opts, &config.path, cf_descriptors) .map_err(|err| internal_error(format!("failed to open database: {err}")))?; diff --git a/resource/ckb.toml b/resource/ckb.toml index 9f99d4bb98..cb47bd5bf5 100644 --- a/resource/ckb.toml +++ b/resource/ckb.toml @@ -48,11 +48,11 @@ dsn = "" # {{ # interval = 600 [db] -# The capacity of RocksDB cache, which caches uncompressed data blocks, indexes and filters, default is 128MB. -# Rocksdb will automatically create and use an 8MB internal cache if you set this value to 0. +# The capacity of RocksDB cache, which caches uncompressed data blocks, indexes and filters, default is 256MB. +# Rocksdb will automatically create and use an 32MB internal cache for each column family by default if you set this value to 0. # To turning off cache, you need to set this value to 0 and set `no_block_cache = true` in the options_file, # however, we strongly discourage this setting, it may lead to severe performance degradation. -cache_size = 134217728 +cache_size = 268435456 # Provide an options file to tune RocksDB for your workload and your system configuration. # More details can be found in [the official tuning guide](https://github.com/facebook/rocksdb/wiki/RocksDB-Tuning-Guide). diff --git a/resource/default.db-options b/resource/default.db-options index bffbdc09e6..5ba523ba50 100644 --- a/resource/default.db-options +++ b/resource/default.db-options @@ -16,7 +16,3 @@ write_buffer_size=8388608 min_write_buffer_number_to_merge=1 max_write_buffer_number=2 max_write_buffer_size_to_maintain=-1 - -[TableOptions/BlockBasedTable "default"] -cache_index_and_filter_blocks=true -pin_l0_filter_and_index_blocks_in_cache=true From 8354d2307075701a34aaedc4bf79ef5b76eca815 Mon Sep 17 00:00:00 2001 From: quake Date: Fri, 27 Oct 2023 11:03:56 +0900 Subject: [PATCH 2/2] fix: only setup cache related options when cache enabled --- db/src/db.rs | 8 +++++--- 1 file changed, 5 insertions(+), 3 deletions(-) diff --git a/db/src/db.rs b/db/src/db.rs index 34f7e3f47d..5845f6c047 100644 --- a/db/src/db.rs +++ b/db/src/db.rs @@ -72,14 +72,16 @@ impl RocksDB { for cf in cf_descriptors.iter_mut() { let mut block_opts = BlockBasedOptions::default(); block_opts.set_ribbon_filter(10.0); - block_opts.set_cache_index_and_filter_blocks(true); - block_opts.set_pin_l0_filter_and_index_blocks_in_cache(true); block_opts.set_index_type(BlockBasedIndexType::TwoLevelIndexSearch); block_opts.set_partition_filters(true); block_opts.set_metadata_block_size(4096); block_opts.set_pin_top_level_index_and_filter(true); match cache { - Some(ref cache) => block_opts.set_block_cache(cache), + Some(ref cache) => { + block_opts.set_block_cache(cache); + block_opts.set_cache_index_and_filter_blocks(true); + block_opts.set_pin_l0_filter_and_index_blocks_in_cache(true); + } None => block_opts.disable_cache(), } // only COLUMN_BLOCK_BODY column family use prefix seek