From 6aca526463f543edb71c5bb664a87b9f23d28880 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=C3=89lo=C3=AFs?= Date: Tue, 23 Apr 2024 13:16:03 +0200 Subject: [PATCH 1/2] add cli param keys_limit --- .../utils/frame/benchmarking-cli/src/storage/cmd.rs | 11 ++++++++++- .../utils/frame/benchmarking-cli/src/storage/read.rs | 8 ++++++-- .../utils/frame/benchmarking-cli/src/storage/write.rs | 8 ++++++-- 3 files changed, 22 insertions(+), 5 deletions(-) diff --git a/substrate/utils/frame/benchmarking-cli/src/storage/cmd.rs b/substrate/utils/frame/benchmarking-cli/src/storage/cmd.rs index 307c9207fdaf..aa224c853afc 100644 --- a/substrate/utils/frame/benchmarking-cli/src/storage/cmd.rs +++ b/substrate/utils/frame/benchmarking-cli/src/storage/cmd.rs @@ -116,6 +116,11 @@ pub struct StorageParams { /// Include child trees in benchmark. #[arg(long)] pub include_child_trees: bool, + + /// Maximum number of keys to read + /// (All keys if not define) + #[arg(long)] + pub keys_limit: Option, } impl StorageCmd { @@ -191,7 +196,11 @@ impl StorageCmd { BA: ClientBackend, { let hash = client.usage_info().chain.best_hash; - let mut keys: Vec<_> = client.storage_keys(hash, None, None)?.collect(); + let mut keys: Vec<_> = if let Some(keys_limit) = self.params.keys_limit { + client.storage_keys(hash, None, None)?.take(keys_limit).collect() + } else { + client.storage_keys(hash, None, None)?.collect() + }; let (mut rng, _) = new_rng(None); keys.shuffle(&mut rng); diff --git a/substrate/utils/frame/benchmarking-cli/src/storage/read.rs b/substrate/utils/frame/benchmarking-cli/src/storage/read.rs index fe72364269d5..ba2d6e4b5b19 100644 --- a/substrate/utils/frame/benchmarking-cli/src/storage/read.rs +++ b/substrate/utils/frame/benchmarking-cli/src/storage/read.rs @@ -40,8 +40,12 @@ impl StorageCmd { let best_hash = client.usage_info().chain.best_hash; info!("Preparing keys from block {}", best_hash); - // Load all keys and randomly shuffle them. - let mut keys: Vec<_> = client.storage_keys(best_hash, None, None)?.collect(); + // Load keys and randomly shuffle them. + let mut keys: Vec<_> = if let Some(keys_limit) = self.params.keys_limit { + client.storage_keys(best_hash, None, None)?.take(keys_limit).collect() + } else { + client.storage_keys(best_hash, None, None)?.collect() + }; let (mut rng, _) = new_rng(None); keys.shuffle(&mut rng); diff --git a/substrate/utils/frame/benchmarking-cli/src/storage/write.rs b/substrate/utils/frame/benchmarking-cli/src/storage/write.rs index 65941497bda4..cc024ef1f6db 100644 --- a/substrate/utils/frame/benchmarking-cli/src/storage/write.rs +++ b/substrate/utils/frame/benchmarking-cli/src/storage/write.rs @@ -60,8 +60,12 @@ impl StorageCmd { let trie = DbStateBuilder::::new(storage.clone(), original_root).build(); info!("Preparing keys from block {}", best_hash); - // Load all KV pairs and randomly shuffle them. - let mut kvs: Vec<_> = trie.pairs(Default::default())?.collect(); + // Load KV pairs and randomly shuffle them. + let mut kvs: Vec<_> = if let Some(keys_limit) = self.params.keys_limit { + trie.pairs(Default::default())?.take(keys_limit).collect() + } else { + trie.pairs(Default::default())?.collect() + }; let (mut rng, _) = new_rng(None); kvs.shuffle(&mut rng); info!("Writing {} keys", kvs.len()); From 6aa86d74931eb40c7dc3afc4564b286dcab7f5b8 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=C3=89lo=C3=AFs?= Date: Tue, 23 Apr 2024 17:11:58 +0200 Subject: [PATCH 2/2] add --random-seed param --- .../utils/frame/benchmarking-cli/src/storage/cmd.rs | 11 +++++++++-- .../utils/frame/benchmarking-cli/src/storage/read.rs | 6 ++++-- .../utils/frame/benchmarking-cli/src/storage/write.rs | 7 +++++-- 3 files changed, 18 insertions(+), 6 deletions(-) diff --git a/substrate/utils/frame/benchmarking-cli/src/storage/cmd.rs b/substrate/utils/frame/benchmarking-cli/src/storage/cmd.rs index aa224c853afc..f8a80db159a2 100644 --- a/substrate/utils/frame/benchmarking-cli/src/storage/cmd.rs +++ b/substrate/utils/frame/benchmarking-cli/src/storage/cmd.rs @@ -121,6 +121,11 @@ pub struct StorageParams { /// (All keys if not define) #[arg(long)] pub keys_limit: Option, + + /// Seed to use for benchs randomness, the same seed allow to replay + /// becnhamrks under the same conditions. + #[arg(long)] + pub random_seed: Option, } impl StorageCmd { @@ -197,11 +202,13 @@ impl StorageCmd { { let hash = client.usage_info().chain.best_hash; let mut keys: Vec<_> = if let Some(keys_limit) = self.params.keys_limit { - client.storage_keys(hash, None, None)?.take(keys_limit).collect() + use sp_core::blake2_256; + let first_key = self.params.random_seed.map(|seed| sp_storage::StorageKey(blake2_256(&seed.to_be_bytes()[..]).to_vec())); + client.storage_keys(hash, None, first_key.as_ref())?.take(keys_limit).collect() } else { client.storage_keys(hash, None, None)?.collect() }; - let (mut rng, _) = new_rng(None); + let (mut rng, _) = new_rng(self.params.random_seed); keys.shuffle(&mut rng); for i in 0..self.params.warmups { diff --git a/substrate/utils/frame/benchmarking-cli/src/storage/read.rs b/substrate/utils/frame/benchmarking-cli/src/storage/read.rs index ba2d6e4b5b19..d504d7f9e4ae 100644 --- a/substrate/utils/frame/benchmarking-cli/src/storage/read.rs +++ b/substrate/utils/frame/benchmarking-cli/src/storage/read.rs @@ -42,11 +42,13 @@ impl StorageCmd { info!("Preparing keys from block {}", best_hash); // Load keys and randomly shuffle them. let mut keys: Vec<_> = if let Some(keys_limit) = self.params.keys_limit { - client.storage_keys(best_hash, None, None)?.take(keys_limit).collect() + use sp_core::blake2_256; + let first_key = self.params.random_seed.map(|seed| sp_storage::StorageKey(blake2_256(&seed.to_be_bytes()[..]).to_vec())); + client.storage_keys(best_hash, None, first_key.as_ref())?.take(keys_limit).collect() } else { client.storage_keys(best_hash, None, None)?.collect() }; - let (mut rng, _) = new_rng(None); + let (mut rng, _) = new_rng(self.params.random_seed); keys.shuffle(&mut rng); let mut child_nodes = Vec::new(); diff --git a/substrate/utils/frame/benchmarking-cli/src/storage/write.rs b/substrate/utils/frame/benchmarking-cli/src/storage/write.rs index cc024ef1f6db..71f931355248 100644 --- a/substrate/utils/frame/benchmarking-cli/src/storage/write.rs +++ b/substrate/utils/frame/benchmarking-cli/src/storage/write.rs @@ -62,11 +62,14 @@ impl StorageCmd { info!("Preparing keys from block {}", best_hash); // Load KV pairs and randomly shuffle them. let mut kvs: Vec<_> = if let Some(keys_limit) = self.params.keys_limit { - trie.pairs(Default::default())?.take(keys_limit).collect() + let start_at = self.params.random_seed.map(|seed| sp_core::blake2_256(&seed.to_be_bytes()[..]).to_vec()); + let mut iter_args = sp_state_machine::IterArgs::default(); + iter_args.start_at = start_at.as_deref(); + trie.pairs(iter_args)?.take(keys_limit).collect() } else { trie.pairs(Default::default())?.collect() }; - let (mut rng, _) = new_rng(None); + let (mut rng, _) = new_rng(self.params.random_seed); kvs.shuffle(&mut rng); info!("Writing {} keys", kvs.len());