mirror of
https://github.com/pezkuwichain/pezkuwi-subxt.git
synced 2026-04-26 13:27:57 +00:00
PoV Reclaim (Clawback) Node Side (#1462)
This PR provides the infrastructure for the pov-reclaim mechanism discussed in #209. The goal is to provide the current proof size to the runtime so it can be used to reclaim storage weight. ## New Host Function - A new host function is provided [here](https://github.com/skunert/polkadot-sdk/blob/5b317fda3be205f4136f10d4490387ccd4f9765d/cumulus/primitives/pov-reclaim/src/lib.rs#L23). It returns the size of the current proof size to the runtime. If recording is not enabled, it returns 0. ## Implementation Overview - Implement option to enable proof recording during import in the client. This is currently enabled for `polkadot-parachain`, `parachain-template` and the cumulus test node. - Make the proof recorder ready for no-std. It was previously only enabled for std environments, but we need to record the proof size in `validate_block` too. - Provide a recorder implementation that only the records the size of incoming nodes and does not store the nodes itself. - Fix benchmarks that were broken by async backing changes - Provide new externalities extension that is registered by default if proof recording is enabled. - I think we should discuss the naming, pov-reclaim was more intuitive to me, but we could also go with clawback like in the issue. ## Impact of proof recording during import With proof recording: 6.3058 Kelem/s Without proof recording: 6.3427 Kelem/s The measured impact on the importing performance is quite low on my machine using the block import benchmark. With proof recording I am seeing a performance hit of 0.585%. --------- Co-authored-by: command-bot <> Co-authored-by: Davide Galassi <davxy@datawok.net> Co-authored-by: Bastian Köcher <git@kchr.de>
This commit is contained in:
@@ -130,10 +130,11 @@ where
|
||||
}
|
||||
|
||||
/// Create the initial parts of a full node with the default genesis block builder.
|
||||
pub fn new_full_parts<TBl, TRtApi, TExec>(
|
||||
pub fn new_full_parts_record_import<TBl, TRtApi, TExec>(
|
||||
config: &Configuration,
|
||||
telemetry: Option<TelemetryHandle>,
|
||||
executor: TExec,
|
||||
enable_import_proof_recording: bool,
|
||||
) -> Result<TFullParts<TBl, TRtApi, TExec>, Error>
|
||||
where
|
||||
TBl: BlockT,
|
||||
@@ -148,7 +149,26 @@ where
|
||||
executor.clone(),
|
||||
)?;
|
||||
|
||||
new_full_parts_with_genesis_builder(config, telemetry, executor, backend, genesis_block_builder)
|
||||
new_full_parts_with_genesis_builder(
|
||||
config,
|
||||
telemetry,
|
||||
executor,
|
||||
backend,
|
||||
genesis_block_builder,
|
||||
enable_import_proof_recording,
|
||||
)
|
||||
}
|
||||
/// Create the initial parts of a full node with the default genesis block builder.
|
||||
pub fn new_full_parts<TBl, TRtApi, TExec>(
|
||||
config: &Configuration,
|
||||
telemetry: Option<TelemetryHandle>,
|
||||
executor: TExec,
|
||||
) -> Result<TFullParts<TBl, TRtApi, TExec>, Error>
|
||||
where
|
||||
TBl: BlockT,
|
||||
TExec: CodeExecutor + RuntimeVersionOf + Clone,
|
||||
{
|
||||
new_full_parts_record_import(config, telemetry, executor, false)
|
||||
}
|
||||
|
||||
/// Create the initial parts of a full node.
|
||||
@@ -158,6 +178,7 @@ pub fn new_full_parts_with_genesis_builder<TBl, TRtApi, TExec, TBuildGenesisBloc
|
||||
executor: TExec,
|
||||
backend: Arc<TFullBackend<TBl>>,
|
||||
genesis_block_builder: TBuildGenesisBlock,
|
||||
enable_import_proof_recording: bool,
|
||||
) -> Result<TFullParts<TBl, TRtApi, TExec>, Error>
|
||||
where
|
||||
TBl: BlockT,
|
||||
@@ -225,6 +246,7 @@ where
|
||||
SyncMode::LightState { .. } | SyncMode::Warp { .. }
|
||||
),
|
||||
wasm_runtime_substitutes,
|
||||
enable_import_proof_recording,
|
||||
},
|
||||
)?;
|
||||
|
||||
|
||||
@@ -77,7 +77,7 @@ use sp_state_machine::{
|
||||
ChildStorageCollection, KeyValueStates, KeyValueStorageLevel, StorageCollection,
|
||||
MAX_NESTED_TRIE_DEPTH,
|
||||
};
|
||||
use sp_trie::{CompactProof, MerkleValue, StorageProof};
|
||||
use sp_trie::{proof_size_extension::ProofSizeExt, CompactProof, MerkleValue, StorageProof};
|
||||
use std::{
|
||||
collections::{HashMap, HashSet},
|
||||
marker::PhantomData,
|
||||
@@ -184,7 +184,7 @@ where
|
||||
)
|
||||
}
|
||||
|
||||
/// Relevant client configuration items relevant for the client.
|
||||
/// Client configuration items.
|
||||
#[derive(Debug, Clone)]
|
||||
pub struct ClientConfig<Block: BlockT> {
|
||||
/// Enable the offchain worker db.
|
||||
@@ -198,6 +198,8 @@ pub struct ClientConfig<Block: BlockT> {
|
||||
/// Map of WASM runtime substitute starting at the child of the given block until the runtime
|
||||
/// version doesn't match anymore.
|
||||
pub wasm_runtime_substitutes: HashMap<NumberFor<Block>, Vec<u8>>,
|
||||
/// Enable recording of storage proofs during block import
|
||||
pub enable_import_proof_recording: bool,
|
||||
}
|
||||
|
||||
impl<Block: BlockT> Default for ClientConfig<Block> {
|
||||
@@ -208,6 +210,7 @@ impl<Block: BlockT> Default for ClientConfig<Block> {
|
||||
wasm_runtime_overrides: None,
|
||||
no_genesis: false,
|
||||
wasm_runtime_substitutes: HashMap::new(),
|
||||
enable_import_proof_recording: false,
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -858,6 +861,14 @@ where
|
||||
|
||||
runtime_api.set_call_context(CallContext::Onchain);
|
||||
|
||||
if self.config.enable_import_proof_recording {
|
||||
runtime_api.record_proof();
|
||||
let recorder = runtime_api
|
||||
.proof_recorder()
|
||||
.expect("Proof recording is enabled in the line above; qed.");
|
||||
runtime_api.register_extension(ProofSizeExt::new(recorder));
|
||||
}
|
||||
|
||||
runtime_api.execute_block(
|
||||
*parent_hash,
|
||||
Block::new(import_block.header.clone(), body.clone()),
|
||||
|
||||
@@ -53,9 +53,10 @@ use sp_runtime::traits::{Block as BlockT, Header as HeaderT};
|
||||
pub use self::{
|
||||
builder::{
|
||||
build_network, new_client, new_db_backend, new_full_client, new_full_parts,
|
||||
new_full_parts_with_genesis_builder, new_native_or_wasm_executor, new_wasm_executor,
|
||||
spawn_tasks, BuildNetworkParams, KeystoreContainer, NetworkStarter, SpawnTasksParams,
|
||||
TFullBackend, TFullCallExecutor, TFullClient,
|
||||
new_full_parts_record_import, new_full_parts_with_genesis_builder,
|
||||
new_native_or_wasm_executor, new_wasm_executor, spawn_tasks, BuildNetworkParams,
|
||||
KeystoreContainer, NetworkStarter, SpawnTasksParams, TFullBackend, TFullCallExecutor,
|
||||
TFullClient,
|
||||
},
|
||||
client::{ClientConfig, LocalCallExecutor},
|
||||
error::Error,
|
||||
|
||||
Reference in New Issue
Block a user