From 4b9ea526d93e38fa837b3abe5497da8ff385b813 Mon Sep 17 00:00:00 2001 From: Eval EXEC Date: Sun, 8 Dec 2024 17:13:41 +0800 Subject: [PATCH 1/6] Let update_default_valid_target.sh update default_assume_valid_target.rs file --- devtools/release/update_default_valid_target.sh | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/devtools/release/update_default_valid_target.sh b/devtools/release/update_default_valid_target.sh index 5f7cb21e30..fd7b9da3e9 100755 --- a/devtools/release/update_default_valid_target.sh +++ b/devtools/release/update_default_valid_target.sh @@ -91,9 +91,9 @@ TEXT_MAINNET=$(print_60_days_ago_block mainnet https://mainnet.ckb.dev https://e printf "TestNet:\n" TEXT_TESTNET=$(print_60_days_ago_block testnet https://testnet.ckb.dev https://pudge.explorer.nervos.org) -echo "${TEXT_HEADER}" > util/constant/src/default_assume_valid_target.rs -echo "${TEXT_MAINNET}" >> util/constant/src/default_assume_valid_target.rs -echo "${TEXT_TESTNET}" >> util/constant/src/default_assume_valid_target.rs +echo "${TEXT_HEADER}" > util/constant/src/latest_assume_valid_target.rs +echo "${TEXT_MAINNET}" >> util/constant/src/latest_assume_valid_target.rs +echo "${TEXT_TESTNET}" >> util/constant/src/latest_assume_valid_target.rs echo -echo this script has overwrite file: util/constant/src/default_assume_valid_target.rs +echo this script has overwrite file: util/constant/src/latest_assume_valid_target.rs echo Please review the changes From 06e471c4eb22d8ff8daec58f6c84f7813aeb3dd8 Mon Sep 17 00:00:00 2001 From: Eval EXEC Date: Sun, 8 Dec 2024 17:14:53 +0800 Subject: [PATCH 2/6] Re-organize util/constant assume_valid_target code, put hardcoded exponential growth target to lastest_assume_valid_target --- ckb-bin/src/cli.rs | 4 +- ckb-bin/src/setup.rs | 60 ++++++---- .../src/default_assume_valid_target.rs | 106 +++++++++++++----- .../src/latest_assume_valid_target.rs | 31 +++++ util/constant/src/lib.rs | 5 +- 5 files changed, 154 insertions(+), 52 deletions(-) create mode 100644 util/constant/src/latest_assume_valid_target.rs diff --git a/ckb-bin/src/cli.rs b/ckb-bin/src/cli.rs index fbda878d75..a8870861ef 100644 --- a/ckb-bin/src/cli.rs +++ b/ckb-bin/src/cli.rs @@ -206,8 +206,8 @@ default(TestNet): {}\n\n You can explicitly set the value to 0x0000000000000000000000000000000000000000000000000000000000000000 \ to disable the default behavior and execute full verification for all blocks, \ ", - ckb_constant::default_assume_valid_target::mainnet::DEFAULT_ASSUME_VALID_TARGET, - ckb_constant::default_assume_valid_target::testnet::DEFAULT_ASSUME_VALID_TARGET)) + ckb_constant::latest_assume_valid_target::mainnet::DEFAULT_ASSUME_VALID_TARGET, + ckb_constant::latest_assume_valid_target::testnet::DEFAULT_ASSUME_VALID_TARGET)) ).arg( Arg::new(ARG_INDEXER) .long(ARG_INDEXER) diff --git a/ckb-bin/src/setup.rs b/ckb-bin/src/setup.rs index 789323d250..0df2aa5c70 100644 --- a/ckb-bin/src/setup.rs +++ b/ckb-bin/src/setup.rs @@ -7,7 +7,7 @@ use ckb_app_config::{ }; use ckb_chain_spec::{consensus::Consensus, ChainSpec}; use ckb_jsonrpc_types::ScriptHashType; -use ckb_logger::info; +use ckb_logger::{error, info}; use ckb_types::{u256, H256, U256}; use clap::ArgMatches; use std::{path::PathBuf, str::FromStr}; @@ -71,33 +71,47 @@ impl Setup { } else { u256!("0x0") }; - - let arg_assume_valid_target = matches.get_one::(cli::ARG_ASSUME_VALID_TARGET); - - config.network.sync.assume_valid_target = - arg_assume_valid_target.and_then(|s| H256::from_str(&s[2..]).ok()); - if config.network.sync.assume_valid_target.is_none() { - config.network.sync.assume_valid_target = match consensus.id.as_str() { + config.network.sync.assume_valid_targets = matches + .get_one::(cli::ARG_ASSUME_VALID_TARGET) + .map(|concacate_targets| { + concacate_targets + .split(',') + .map(|s| H256::from_str(&s[2..])) + .collect::, _>>() + .map_err(|err| { + error!("Invalid assume valid target: {}", err); + ExitCode::Cli + }) + }) + .transpose()?; // Converts Result, E> to Option> + + if config.network.sync.assume_valid_targets.is_none() { + config.network.sync.assume_valid_targets = match consensus.id.as_str() { ckb_constant::hardfork::mainnet::CHAIN_SPEC_NAME => Some( - H256::from_str(&ckb_constant::default_assume_valid_target::mainnet::DEFAULT_ASSUME_VALID_TARGET[2..]) - .expect("default assume_valid_target for mainnet must be valid"), - ), + ckb_constant::default_assume_valid_target::mainnet::default_assume_valid_targets().iter().map(|target| +H256::from_str(&target[2..]).expect("default assume_valid_target for mainnet must be valid")).collect::>()), ckb_constant::hardfork::testnet::CHAIN_SPEC_NAME => Some( - H256::from_str(&ckb_constant::default_assume_valid_target::testnet::DEFAULT_ASSUME_VALID_TARGET[2..]) - .expect("default assume_valid_target for testnet must be valid"), - ), - _ => None, + ckb_constant::default_assume_valid_target::testnet::default_assume_valid_targets().iter().map(|target| +H256::from_str(&target[2..]).expect("default assume_valid_target for testnet must be valid")).collect::>()), + _ => None, }; } - if let Some(ref assume_valid_target) = config.network.sync.assume_valid_target { - if assume_valid_target - == &H256::from_slice(&[0; 32]).expect("must parse Zero h256 successful") - { - info!("Disable assume valid target since assume_valid_target is zero"); - config.network.sync.assume_valid_target = None - } else { - info!("assume_valid_target set to 0x{}", assume_valid_target); + if let Some(ref assume_valid_targets) = config.network.sync.assume_valid_targets { + if let Some(first_target) = assume_valid_targets.first() { + if assume_valid_targets.len() == 1 { + if first_target + == &H256::from_slice(&[0; 32]).expect("must parse Zero h256 successful") + { + info!("Disable assume valid targets since assume_valid_targets is zero"); + config.network.sync.assume_valid_targets = None; + } else { + info!( + "assume_valid_targets set to {:?}", + config.network.sync.assume_valid_targets + ); + } + } } } diff --git a/util/constant/src/default_assume_valid_target.rs b/util/constant/src/default_assume_valid_target.rs index 1c6f1d1271..fe871c0ccf 100644 --- a/util/constant/src/default_assume_valid_target.rs +++ b/util/constant/src/default_assume_valid_target.rs @@ -1,31 +1,85 @@ -/// The mod mainnet and mod testnet's codes are generated -/// by script: ./devtools/release/update_default_valid_target.sh -/// Please don't modify them manually. -/// +/// Get default assume valid targets -/// sync config related to mainnet +/// mainnet pub mod mainnet { - /// Default assume valid target for mainnet, expect to be a block 60 days ago. - /// - /// Need to update when CKB's new release - /// in mainnet: the 60 days ago block is: - /// height: 14050088 - /// hash: 0x323642363d254e830556ba670907d4455c2aeb8a38a227da7401e92a297efede - /// date: Wed Sep 18 08:24:48 AM CST 2024 - /// you can view this block in https://explorer.nervos.org/block/0x323642363d254e830556ba670907d4455c2aeb8a38a227da7401e92a297efede - pub const DEFAULT_ASSUME_VALID_TARGET: &str = - "0x323642363d254e830556ba670907d4455c2aeb8a38a227da7401e92a297efede"; + use crate::latest_assume_valid_target; + + /// get mainnet related default assume valid targets + pub fn default_assume_valid_targets() -> Vec<&'static str> { + vec![ + // height: 500000; https://explorer.nervos.org/block/0xb72f4d9758a36a2f9d4b8aea5a11d232e3e48332b76ec350f0a375fac10317a4 + "0xb72f4d9758a36a2f9d4b8aea5a11d232e3e48332b76ec350f0a375fac10317a4", + // height: 1000000; https://explorer.nervos.org/block/0x7544e2a9db2054fbe42215ece2e5d31f175972cfeccaa7597c8ff3ec5c8b7d67 + "0x7544e2a9db2054fbe42215ece2e5d31f175972cfeccaa7597c8ff3ec5c8b7d67", + // height: 2000000; https://explorer.nervos.org/block/0xc0c1ca7dcfa5862b9d2afeb5ea94db14744b8146c9005982879030f01e1f47cb + "0xc0c1ca7dcfa5862b9d2afeb5ea94db14744b8146c9005982879030f01e1f47cb", + // height: 3000000; https://explorer.nervos.org/block/0x36ff0ea1100e7892367b5004a362780c14c85fc2812bb6bd511e1c3a131c3fda + "0x36ff0ea1100e7892367b5004a362780c14c85fc2812bb6bd511e1c3a131c3fda", + // height: 4000000; https://explorer.nervos.org/block/0xcd925c9baa8c3110980546c916dad122dc69111780e49b50c3bb407ab7b6aa1c + "0xcd925c9baa8c3110980546c916dad122dc69111780e49b50c3bb407ab7b6aa1c", + // height: 5000000; https://explorer.nervos.org/block/0x10898dd0307ef95e9086794ae7070d2f960725d1dd1e0800044eb8d8b2547da6 + "0x10898dd0307ef95e9086794ae7070d2f960725d1dd1e0800044eb8d8b2547da6", + // height: 6000000; https://explorer.nervos.org/block/0x0d78219b6972c21f33350958882da3e961c2ebbddc4521bf45ee47139b331333 + "0x0d78219b6972c21f33350958882da3e961c2ebbddc4521bf45ee47139b331333", + // height: 7000000; https://explorer.nervos.org/block/0x1c280be16bf3366cf890cd5a8c5dc4eeed8c6ddeeb988a482d7feabb3bd014c6 + "0x1c280be16bf3366cf890cd5a8c5dc4eeed8c6ddeeb988a482d7feabb3bd014c6", + // height: 8000000; https://explorer.nervos.org/block/0x063ccfcdbad01922792914f0bd61e47930bbb4a531f711013a24210638c0174a + "0x063ccfcdbad01922792914f0bd61e47930bbb4a531f711013a24210638c0174a", + // height: 9000000; https://explorer.nervos.org/block/0xcf95c190a0054ce2404ad70d9befb5ec78579dd0a9ddb95776c5ac1bc5ddeed1 + "0xcf95c190a0054ce2404ad70d9befb5ec78579dd0a9ddb95776c5ac1bc5ddeed1", + // height: 10000000; https://explorer.nervos.org/block/0xe784f617bf1e13a3ac1a564e361b7e6298364193246e11cd328243f329f3592d + "0xe784f617bf1e13a3ac1a564e361b7e6298364193246e11cd328243f329f3592d", + // height: 11000000; https://explorer.nervos.org/block/0xe9b97767424dd04aa65a1f7ad562b0faf8dd0fbf2a213d1586ea7969160f5996 + "0xe9b97767424dd04aa65a1f7ad562b0faf8dd0fbf2a213d1586ea7969160f5996", + // height: 12000000; https://explorer.nervos.org/block/0x2210a9bd5a292888f79ec7547ac3ea79c731df8bfe2049934f3206cabdc07f54 + "0x2210a9bd5a292888f79ec7547ac3ea79c731df8bfe2049934f3206cabdc07f54", + // height: 13000000; https://explorer.nervos.org/block/0xcffc6a0a1f363db8fdbe2fea916ab5cd8851dd479bc04003dab88c9379dca1d0 + "0xcffc6a0a1f363db8fdbe2fea916ab5cd8851dd479bc04003dab88c9379dca1d0", + // height: 14000000; https://explorer.nervos.org/block/0xf283cacaa21556957b9621b8ac303a0b2c06434c26a1b53b1e590219d2c7313a + "0xf283cacaa21556957b9621b8ac303a0b2c06434c26a1b53b1e590219d2c7313a", + latest_assume_valid_target::mainnet::DEFAULT_ASSUME_VALID_TARGET, + ] + } } -/// sync config related to testnet + +/// testnet pub mod testnet { - /// Default assume valid target for testnet, expect to be a block 60 days ago. - /// - /// Need to update when CKB's new release - /// in testnet: the 60 days ago block is: - /// height: 14613282 - /// hash: 0x9674c22c68f4b65ff97944151c39ff3f8108707b4bc86378393b3312a823db77 - /// date: Wed Sep 18 08:25:27 AM CST 2024 - /// you can view this block in https://pudge.explorer.nervos.org/block/0x9674c22c68f4b65ff97944151c39ff3f8108707b4bc86378393b3312a823db77 - pub const DEFAULT_ASSUME_VALID_TARGET: &str = - "0x9674c22c68f4b65ff97944151c39ff3f8108707b4bc86378393b3312a823db77"; + use crate::latest_assume_valid_target; + + /// get testnet related default assume valid targets + pub fn default_assume_valid_targets() -> Vec<&'static str> { + vec![ + // height: 500000; https://testnet.explorer.nervos.org/block/0xf9c73f3db9a7c6707c3c6800a9a0dbd5a2edf69e3921832f65275dcd71f7871c + "0xf9c73f3db9a7c6707c3c6800a9a0dbd5a2edf69e3921832f65275dcd71f7871c", + // height: 1000000; https://testnet.explorer.nervos.org/block/0x935a48f2660fd141121114786edcf17ef5789c6c2fe7aca04ea27813b30e1fa3 + "0x935a48f2660fd141121114786edcf17ef5789c6c2fe7aca04ea27813b30e1fa3", + // height: 2000000; https://testnet.explorer.nervos.org/block/0xf4d1648131b7bc4a0c9dbc442d240395c89a0c77b0cc197dce8794cd93669b32 + "0xf4d1648131b7bc4a0c9dbc442d240395c89a0c77b0cc197dce8794cd93669b32", + // height: 3000000; https://testnet.explorer.nervos.org/block/0x1d1bd2a6a50d9532b7131c5d0b05c006fb354a0341a504e54eaf39b27acc620d + "0x1d1bd2a6a50d9532b7131c5d0b05c006fb354a0341a504e54eaf39b27acc620d", + // height: 4000000; https://testnet.explorer.nervos.org/block/0xb33c0e0a649003ab65062e93a3126a2235f6e7c3ca1b16fe9938816d846bb14f + "0xb33c0e0a649003ab65062e93a3126a2235f6e7c3ca1b16fe9938816d846bb14f", + // height: 5000000; https://testnet.explorer.nervos.org/block/0xff4f979d8ab597a5836c533828d5253021c05f2614470fd8a4df7724ff8ec5e1 + "0xff4f979d8ab597a5836c533828d5253021c05f2614470fd8a4df7724ff8ec5e1", + // height: 6000000; https://testnet.explorer.nervos.org/block/0xfdb427f18e03cee68947609db1f592ee2651181528da35fb62b64d4d4d5d749a + "0xfdb427f18e03cee68947609db1f592ee2651181528da35fb62b64d4d4d5d749a", + // height: 7000000; https://testnet.explorer.nervos.org/block/0xf9e1c6398f524c10b358dca7e000f59992004fda68c801453ed4da06bc3c6ecc + "0xf9e1c6398f524c10b358dca7e000f59992004fda68c801453ed4da06bc3c6ecc", + // height: 8000000; https://testnet.explorer.nervos.org/block/0x2be0f327e78032f495f90da159883da84f2efd5025fde106a6a7590b8fca6647 + "0x2be0f327e78032f495f90da159883da84f2efd5025fde106a6a7590b8fca6647", + // height: 9000000; https://testnet.explorer.nervos.org/block/0xba1e8db7d162445979f2c73392208b882ea01c7627a8a98be82789d6f130ce35 + "0xba1e8db7d162445979f2c73392208b882ea01c7627a8a98be82789d6f130ce35", + // height: 10000000; https://testnet.explorer.nervos.org/block/0xf64c95cfa813e0aa1ae2e0e28af4723134263c9862979c953842511381b7d8c6 + "0xf64c95cfa813e0aa1ae2e0e28af4723134263c9862979c953842511381b7d8c6", + // height: 11000000; https://testnet.explorer.nervos.org/block/0x0a9e4de75031163fefc5e7c0d40adadb2d7cb23eb9b1b2dae46872e921f4bcf1 + "0x0a9e4de75031163fefc5e7c0d40adadb2d7cb23eb9b1b2dae46872e921f4bcf1", + // height: 12000000; https://testnet.explorer.nervos.org/block/0x9f24177a181798b7ad63dfc8e0b89fe0ce60c099e86743675070f428ca1037b4 + "0x9f24177a181798b7ad63dfc8e0b89fe0ce60c099e86743675070f428ca1037b4", + // height: 13000000; https://testnet.explorer.nervos.org/block/0xc884fb5ca8cc2acddf6ce4888dc7fe0f583bb0dd4f80c5be31bed87268b1ca2f + "0xc884fb5ca8cc2acddf6ce4888dc7fe0f583bb0dd4f80c5be31bed87268b1ca2f", + // height: 14000000; https://testnet.explorer.nervos.org/block/0xfb7da0ff926540463e3a9168cf0cd73113c24e4692a561525554c87c62aa3475 + "0xfb7da0ff926540463e3a9168cf0cd73113c24e4692a561525554c87c62aa3475", + latest_assume_valid_target::testnet::DEFAULT_ASSUME_VALID_TARGET, + ] + } } diff --git a/util/constant/src/latest_assume_valid_target.rs b/util/constant/src/latest_assume_valid_target.rs new file mode 100644 index 0000000000..1c6f1d1271 --- /dev/null +++ b/util/constant/src/latest_assume_valid_target.rs @@ -0,0 +1,31 @@ +/// The mod mainnet and mod testnet's codes are generated +/// by script: ./devtools/release/update_default_valid_target.sh +/// Please don't modify them manually. +/// + +/// sync config related to mainnet +pub mod mainnet { + /// Default assume valid target for mainnet, expect to be a block 60 days ago. + /// + /// Need to update when CKB's new release + /// in mainnet: the 60 days ago block is: + /// height: 14050088 + /// hash: 0x323642363d254e830556ba670907d4455c2aeb8a38a227da7401e92a297efede + /// date: Wed Sep 18 08:24:48 AM CST 2024 + /// you can view this block in https://explorer.nervos.org/block/0x323642363d254e830556ba670907d4455c2aeb8a38a227da7401e92a297efede + pub const DEFAULT_ASSUME_VALID_TARGET: &str = + "0x323642363d254e830556ba670907d4455c2aeb8a38a227da7401e92a297efede"; +} +/// sync config related to testnet +pub mod testnet { + /// Default assume valid target for testnet, expect to be a block 60 days ago. + /// + /// Need to update when CKB's new release + /// in testnet: the 60 days ago block is: + /// height: 14613282 + /// hash: 0x9674c22c68f4b65ff97944151c39ff3f8108707b4bc86378393b3312a823db77 + /// date: Wed Sep 18 08:25:27 AM CST 2024 + /// you can view this block in https://pudge.explorer.nervos.org/block/0x9674c22c68f4b65ff97944151c39ff3f8108707b4bc86378393b3312a823db77 + pub const DEFAULT_ASSUME_VALID_TARGET: &str = + "0x9674c22c68f4b65ff97944151c39ff3f8108707b4bc86378393b3312a823db77"; +} diff --git a/util/constant/src/lib.rs b/util/constant/src/lib.rs index 41ce1df37b..fd84010230 100644 --- a/util/constant/src/lib.rs +++ b/util/constant/src/lib.rs @@ -11,5 +11,8 @@ pub mod store; /// sync constant pub mod sync; -/// hardcoded default assume valid target +/// default assume valid target pub mod default_assume_valid_target; + +/// hardcoded default assume valid target +pub mod latest_assume_valid_target; From be801cd242842e96215f2ed92a94a4f03e571b02 Mon Sep 17 00:00:00 2001 From: Eval EXEC Date: Sun, 8 Dec 2024 17:15:55 +0800 Subject: [PATCH 3/6] Refactor type of assume_valid_target from `H256` to `Vec` Signed-off-by: Eval EXEC --- rpc/src/module/net.rs | 2 +- shared/src/shared.rs | 10 +++++----- shared/src/shared_builder.rs | 24 ++++++++++++++++-------- util/app-config/src/configs/network.rs | 2 +- 4 files changed, 23 insertions(+), 15 deletions(-) diff --git a/rpc/src/module/net.rs b/rpc/src/module/net.rs index de75699e68..855cefae7a 100644 --- a/rpc/src/module/net.rs +++ b/rpc/src/module/net.rs @@ -739,7 +739,7 @@ impl NetRpc for NetRpcImpl { let unverified_tip = shared.get_unverified_tip(); let sync_state = SyncState { ibd: chain.is_initial_block_download(), - assume_valid_target_reached: shared.assume_valid_target().is_none(), + assume_valid_target_reached: shared.assume_valid_targets().is_none(), assume_valid_target: shared .assume_valid_target_specified() .as_ref() diff --git a/shared/src/shared.rs b/shared/src/shared.rs index 2939230a5f..8b523bfc83 100644 --- a/shared/src/shared.rs +++ b/shared/src/shared.rs @@ -62,7 +62,7 @@ pub struct Shared { pub(crate) async_handle: Handle, pub(crate) ibd_finished: Arc, - pub(crate) assume_valid_target: Arc>>, + pub(crate) assume_valid_targets: Arc>>>, pub(crate) assume_valid_target_specified: Arc>, pub header_map: Arc, @@ -83,7 +83,7 @@ impl Shared { async_handle: Handle, ibd_finished: Arc, - assume_valid_target: Arc>>, + assume_valid_targets: Arc>>>, assume_valid_target_specified: Arc>, header_map: Arc, block_status_map: Arc>, @@ -106,7 +106,7 @@ impl Shared { snapshot_mgr, async_handle, ibd_finished, - assume_valid_target, + assume_valid_targets, assume_valid_target_specified, header_map, block_status_map, @@ -467,8 +467,8 @@ impl Shared { ); } - pub fn assume_valid_target(&self) -> MutexGuard> { - self.assume_valid_target.lock() + pub fn assume_valid_targets(&self) -> MutexGuard>> { + self.assume_valid_targets.lock() } pub fn assume_valid_target_specified(&self) -> Arc> { diff --git a/shared/src/shared_builder.rs b/shared/src/shared_builder.rs index 47f0a85e4e..72b0ce3343 100644 --- a/shared/src/shared_builder.rs +++ b/shared/src/shared_builder.rs @@ -25,6 +25,7 @@ use ckb_tx_pool::{ }; use ckb_types::core::hardfork::HardForks; use ckb_types::prelude::Pack; +use ckb_types::H256; use ckb_types::{ core::service::PoolTransactionEntry, core::tx_pool::Reject, core::EpochExt, core::HeaderView, }; @@ -352,10 +353,12 @@ impl SharedBuilder { sync_config: &SyncConfig, snapshot: &Snapshot, ) -> bool { - if let Some(ref target) = sync_config.assume_valid_target { - if snapshot.block_exists(&target.pack()) { - info!("assume valid target is already in db, CKB will do full verification from now on"); - return true; + if let Some(ref target) = sync_config.assume_valid_targets { + if let Some(last_target) = target.last() { + if snapshot.block_exists(&last_target.pack()) { + info!("assume valid target is already in db, CKB will do full verification from now on"); + return true; + } } } false @@ -442,14 +445,19 @@ impl SharedBuilder { let block_status_map = Arc::new(DashMap::new()); - let assume_valid_target = Arc::new(Mutex::new({ + let assume_valid_targets = Arc::new(Mutex::new({ if Self::check_assume_valid_target_already_exists(&sync_config, &snapshot) { None } else { - sync_config.assume_valid_target.clone() + sync_config.assume_valid_targets.clone() } })); - let assume_valid_target_specified = Arc::new(sync_config.assume_valid_target); + + let assume_valid_target_specified: Arc> = Arc::new( + sync_config + .assume_valid_targets + .and_then(|targets| targets.last().cloned()), + ); let shared = Shared::new( store, @@ -460,7 +468,7 @@ impl SharedBuilder { snapshot_mgr, async_handle, ibd_finished, - assume_valid_target, + assume_valid_targets, assume_valid_target_specified, header_map, block_status_map, diff --git a/util/app-config/src/configs/network.rs b/util/app-config/src/configs/network.rs index 34eac57790..b29de05146 100644 --- a/util/app-config/src/configs/network.rs +++ b/util/app-config/src/configs/network.rs @@ -106,7 +106,7 @@ pub struct SyncConfig { pub header_map: HeaderMapConfig, /// Block hash of assume valid target #[serde(skip, default)] - pub assume_valid_target: Option, + pub assume_valid_targets: Option>, /// Proof of minimum work during synchronization #[serde(skip, default)] pub min_chain_work: U256, From ddf7394cdf76ac482e8af7ea80ca50a4ddfc2b86 Mon Sep 17 00:00:00 2001 From: Eval EXEC Date: Sun, 8 Dec 2024 17:16:55 +0800 Subject: [PATCH 4/6] Add `FetchToTarget(BlockNumber)` to `enum Canstart` Signed-off-by: Eval EXEC --- sync/src/synchronizer/block_fetcher.rs | 8 ++- sync/src/synchronizer/mod.rs | 74 ++++++++++++++++++-------- 2 files changed, 57 insertions(+), 25 deletions(-) diff --git a/sync/src/synchronizer/block_fetcher.rs b/sync/src/synchronizer/block_fetcher.rs index b4d87cb3f6..2fdebbeed4 100644 --- a/sync/src/synchronizer/block_fetcher.rs +++ b/sync/src/synchronizer/block_fetcher.rs @@ -9,6 +9,7 @@ use ckb_network::PeerIndex; use ckb_shared::block_status::BlockStatus; use ckb_shared::types::{HeaderIndex, HeaderIndexView}; use ckb_systemtime::unix_time_as_millis; +use ckb_types::core::BlockNumber; use ckb_types::packed; use ckb_types::BlockNumberAndHash; use std::cmp::min; @@ -91,7 +92,7 @@ impl BlockFetcher { Some(last_common) } - pub fn fetch(self) -> Option>> { + pub fn fetch(self, fetch_end: BlockNumber) -> Option>> { let _trace_timecost: Option = { ckb_metrics::handle().map(|handle| handle.ckb_sync_block_fetch_duration.start_timer()) }; @@ -186,7 +187,10 @@ impl BlockFetcher { IBDState::Out => last_common.number() + 1, } }; - let mut end = min(best_known.number(), start + BLOCK_DOWNLOAD_WINDOW); + let mut end = min( + fetch_end, + min(best_known.number(), start + BLOCK_DOWNLOAD_WINDOW), + ); let n_fetch = min( end.saturating_sub(start) as usize + 1, state.read_inflight_blocks().peer_can_fetch_count(self.peer), diff --git a/sync/src/synchronizer/mod.rs b/sync/src/synchronizer/mod.rs index 83aa1213c3..b156478fee 100644 --- a/sync/src/synchronizer/mod.rs +++ b/sync/src/synchronizer/mod.rs @@ -67,6 +67,7 @@ const NOT_IBD_BLOCK_FETCH_INTERVAL: Duration = Duration::from_millis(200); #[derive(Copy, Clone)] enum CanStart { + FetchToTarget(BlockNumber), Ready, MinWorkNotReach, AssumeValidNotFound, @@ -90,25 +91,34 @@ impl BlockFetchCMD { fn process_fetch_cmd(&mut self, cmd: FetchCMD) { let FetchCMD { peers, ibd_state }: FetchCMD = cmd; - match self.can_start() { - CanStart::Ready => { - for peer in peers { - if ckb_stop_handler::has_received_stop_signal() { - return; - } + let fetch_blocks_fn = |cmd: &mut BlockFetchCMD, assume_target: BlockNumber| { + for peer in peers { + if ckb_stop_handler::has_received_stop_signal() { + return; + } - if let Some(fetch) = - BlockFetcher::new(Arc::clone(&self.sync_shared), peer, ibd_state).fetch() - { - for item in fetch { - if ckb_stop_handler::has_received_stop_signal() { - return; - } - BlockFetchCMD::send_getblocks(item, &self.p2p_control, peer); + let mut fetch_end: BlockNumber = u64::MAX; + if assume_target != 0 { + fetch_end = assume_target + } + + if let Some(fetch) = + BlockFetcher::new(Arc::clone(&cmd.sync_shared), peer, ibd_state) + .fetch(fetch_end) + { + for item in fetch { + if ckb_stop_handler::has_received_stop_signal() { + return; } + BlockFetchCMD::send_getblocks(item, &cmd.p2p_control, peer); } } } + }; + + match self.can_start() { + CanStart::FetchToTarget(assume_target) => fetch_blocks_fn(self, assume_target), + CanStart::Ready => fetch_blocks_fn(self, BlockNumber::MAX), CanStart::MinWorkNotReach => { let best_known = self.sync_shared.state().shared_best_header_ref(); let number = best_known.number(); @@ -129,8 +139,9 @@ impl BlockFetchCMD { let best_known = state.shared_best_header_ref(); let number = best_known.number(); let assume_valid_target: Byte32 = shared - .assume_valid_target() + .assume_valid_targets() .as_ref() + .and_then(|targets| targets.first()) .map(Pack::pack) .expect("assume valid target must exist"); @@ -234,15 +245,28 @@ impl BlockFetchCMD { }; let assume_valid_target_find = |flag: &mut CanStart| { - let mut assume_valid_target = shared.assume_valid_target(); - if let Some(ref target) = *assume_valid_target { - match shared.header_map().get(&target.pack()) { + let mut assume_valid_targets = shared.assume_valid_targets(); + if let Some(ref targets) = *assume_valid_targets { + if targets.is_empty() { + assume_valid_targets.take(); + *flag = CanStart::Ready; + return; + } + let first_target = targets + .first() + .expect("has checked targets is not empty, assume valid target must exist"); + match shared.header_map().get(&first_target.pack()) { Some(header) => { - *flag = CanStart::Ready; - info!("assume valid target found in header_map; CKB will start fetch blocks now"); + if matches!(*flag, CanStart::FetchToTarget(fetch_target) if fetch_target == header.number()) + { + // BlockFetchCMD has set the fetch target, no need to set it again + } else { + *flag = CanStart::FetchToTarget(header.number()); + info!("assume valid target found in header_map; CKB will start fetch blocks to {:?} now", header.number_and_hash()); + } // Blocks that are no longer in the scope of ibd must be forced to verify if unix_time_as_millis().saturating_sub(header.timestamp()) < MAX_TIP_AGE { - assume_valid_target.take(); + assume_valid_targets.take(); warn!("the duration gap between 'assume valid target' and 'now' is less than 24h; CKB will ignore the specified assume valid target and do full verification from now on"); } } @@ -254,7 +278,7 @@ impl BlockFetchCMD { { warn!("the duration gap between 'shared_best_header' and 'now' is less than 24h, but CKB haven't found the assume valid target in header_map; CKB will ignore the specified assume valid target and do full verification from now on"); *flag = CanStart::Ready; - assume_valid_target.take(); + assume_valid_targets.take(); } } } @@ -264,6 +288,10 @@ impl BlockFetchCMD { }; match self.can_start { + CanStart::FetchToTarget(_) => { + assume_valid_target_find(&mut self.can_start); + self.can_start + } CanStart::Ready => self.can_start, CanStart::MinWorkNotReach => { min_work_reach(&mut self.can_start); @@ -453,7 +481,7 @@ impl Synchronizer { peer: PeerIndex, ibd: IBDState, ) -> Option>> { - BlockFetcher::new(Arc::clone(&self.shared), peer, ibd).fetch() + BlockFetcher::new(Arc::clone(&self.shared), peer, ibd).fetch(BlockNumber::MAX) } pub(crate) fn on_connected(&self, nc: &dyn CKBProtocolContext, peer: PeerIndex) { From e40e17afe5765d42858aa1bfaf808d853af16438 Mon Sep 17 00:00:00 2001 From: Eval EXEC Date: Sun, 8 Dec 2024 17:20:39 +0800 Subject: [PATCH 5/6] Let ckb-chain select rigth `Switch` for assume_valid_target array --- chain/src/verify.rs | 24 ++++++++++++++++-------- 1 file changed, 16 insertions(+), 8 deletions(-) diff --git a/chain/src/verify.rs b/chain/src/verify.rs index dbd1839b64..56a9aeace6 100644 --- a/chain/src/verify.rs +++ b/chain/src/verify.rs @@ -199,14 +199,22 @@ impl ConsumeUnverifiedBlockProcessor { switch: Option, ) -> VerifyResult { let switch: Switch = switch.unwrap_or_else(|| { - let mut assume_valid_target = self.shared.assume_valid_target(); - match *assume_valid_target { - Some(ref target) => { - // if the target has been reached, delete it - if target - == &ckb_types::prelude::Unpack::::unpack(&BlockView::hash(block)) - { - assume_valid_target.take(); + let mut assume_valid_targets = self.shared.assume_valid_targets(); + match *assume_valid_targets { + Some(ref mut targets) => { + // + let block_hash: H256 = + ckb_types::prelude::Unpack::::unpack(&BlockView::hash(block)); + if targets.first().eq(&Some(&block_hash)) { + targets.remove(0); + info!("CKB reached one assume_valid_target: 0x{}", block_hash); + } + + if targets.is_empty() { + assume_valid_targets.take(); + info!( + "CKB reached all assume_valid_targets, will do full verification now" + ); Switch::NONE } else { Switch::DISABLE_SCRIPT From 2a98841c3b28d9dad002006a6ff1a66db1ed8c5d Mon Sep 17 00:00:00 2001 From: Eval EXEC Date: Thu, 9 Jan 2025 13:13:47 +0800 Subject: [PATCH 6/6] Remove already exists target before ckb-sync start Signed-off-by: Eval EXEC --- shared/src/shared_builder.rs | 39 +++++++++++++++++++----------------- 1 file changed, 21 insertions(+), 18 deletions(-) diff --git a/shared/src/shared_builder.rs b/shared/src/shared_builder.rs index 72b0ce3343..4c671d63d2 100644 --- a/shared/src/shared_builder.rs +++ b/shared/src/shared_builder.rs @@ -348,22 +348,6 @@ impl SharedBuilder { Ok((snapshot, proposal_table)) } - /// Check whether the data already exists in the database before starting - fn check_assume_valid_target_already_exists( - sync_config: &SyncConfig, - snapshot: &Snapshot, - ) -> bool { - if let Some(ref target) = sync_config.assume_valid_targets { - if let Some(last_target) = target.last() { - if snapshot.block_exists(&last_target.pack()) { - info!("assume valid target is already in db, CKB will do full verification from now on"); - return true; - } - } - } - false - } - /// TODO(doc): @quake pub fn build(self) -> Result<(Shared, SharedPackage), ExitCode> { let SharedBuilder { @@ -446,10 +430,29 @@ impl SharedBuilder { let block_status_map = Arc::new(DashMap::new()); let assume_valid_targets = Arc::new(Mutex::new({ - if Self::check_assume_valid_target_already_exists(&sync_config, &snapshot) { + let not_exists_targets: Option> = + sync_config.assume_valid_targets.clone().map(|targets| { + targets + .iter() + .filter(|&target_hash| { + let exists = snapshot.block_exists(&target_hash.pack()); + if exists { + info!("assume valid target 0x{} already exists in db", target_hash); + } + !exists + }) + .cloned() + .collect::>() + }); + + if not_exists_targets + .as_ref() + .is_some_and(|targets| targets.is_empty()) + { + info!("all assume valid targets is already in db, CKB will do full verification from now on"); None } else { - sync_config.assume_valid_targets.clone() + not_exists_targets } }));