Skip to content

Commit

Permalink
Add assume_valid_target to sync_state RPC
Browse files Browse the repository at this point in the history
Signed-off-by: Eval EXEC <execvy@gmail.com>
  • Loading branch information
eval-exec committed Jun 21, 2024
1 parent 247befe commit a2f860d
Show file tree
Hide file tree
Showing 7 changed files with 70 additions and 18 deletions.
4 changes: 1 addition & 3 deletions ckb-bin/src/subcommand/run.rs
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,7 @@ pub fn run(args: RunArgs, version: Version, async_handle: Handle) -> Result<(),
deadlock_detection();

info!("ckb version: {}", version);
let mut launcher = Launcher::new(args, version, async_handle);
let launcher = Launcher::new(args, version, async_handle);

let block_assembler_config = launcher.sanitize_block_assembler_config()?;
let miner_enable = block_assembler_config.is_some();
Expand Down Expand Up @@ -40,8 +40,6 @@ pub fn run(args: RunArgs, version: Version, async_handle: Handle) -> Result<(),
Some(shared.store().db().inner()),
);

launcher.check_assume_valid_target(&shared);

let chain_controller = launcher.start_chain_service(&shared, pack.take_proposal_table());

launcher.start_block_filter(&shared);
Expand Down
12 changes: 12 additions & 0 deletions rpc/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -4138,12 +4138,16 @@ Response
"id": 42,
"jsonrpc": "2.0",
"result": {
"assume_valid_target": "0x0000000000000000000000000000000000000000000000000000000000000000",
"assume_valid_target_reached": true,
"best_known_block_number": "0x400",
"best_known_block_timestamp": "0x5cd2b117",
"fast_time": "0x3e8",
"ibd": true,
"inflight_blocks_count": "0x0",
"low_time": "0x5dc",
"min_chain_work": "0x3314412053c82802a7",
"min_chain_work_reached": true,
"normal_time": "0x4e2",
"orphan_blocks_count": "0x0",
"orphan_blocks_size": "0x0"
Expand Down Expand Up @@ -6833,6 +6837,10 @@ The overall chain synchronization state of this local node.

`SyncState` is a JSON object with the following fields.

* `assume_valid_target`: [`Byte32`](#type-byte32) - The assume_valid_target specified by ckb, if no assume_valid_target, this will be all zero.

* `assume_valid_target_reached`: `boolean` - Is ckb reached the assume_valid_target? If no assume_valid_target, this will be true.

* `best_known_block_number`: [`Uint64`](#type-uint64) - This is the best known block number observed by the local node from the P2P network.

The best here means that the block leads a chain which has the best known accumulated difficulty.
Expand All @@ -6853,6 +6861,10 @@ The overall chain synchronization state of this local node.

* `low_time`: [`Uint64`](#type-uint64) - The download scheduler's time analysis data, the low is the 9/10 of the cut-off point, unit ms

* `min_chain_work`: [`Uint128`](#type-uint128) - The CKB hardcoded MIN_CHAIN_WORK_500K

* `min_chain_work_reached`: `boolean` - Is ckb reached the MIN_CHAIN_WORK_500K?

* `normal_time`: [`Uint64`](#type-uint64) - The download scheduler's time analysis data, the normal is the 4/5 of the cut-off point, unit ms

* `orphan_blocks_count`: [`Uint64`](#type-uint64) - Count of orphan blocks the local node has downloaded.
Expand Down
19 changes: 19 additions & 0 deletions rpc/src/module/net.rs
Original file line number Diff line number Diff line change
@@ -1,12 +1,14 @@
use crate::error::RPCError;
use async_trait::async_trait;
use ckb_app_config::MIN_CHAIN_WORK_500K;
use ckb_jsonrpc_types::{
BannedAddr, LocalNode, LocalNodeProtocol, NodeAddress, PeerSyncState, RemoteNode,
RemoteNodeProtocol, SyncState, Timestamp,
};
use ckb_network::{extract_peer_id, multiaddr::Multiaddr, NetworkController};
use ckb_sync::SyncShared;
use ckb_systemtime::unix_time_as_millis;
use ckb_types::prelude::Pack;
use jsonrpc_core::Result;
use jsonrpc_utils::rpc;
use std::sync::Arc;
Expand Down Expand Up @@ -361,12 +363,16 @@ pub trait NetRpc {
/// "id": 42,
/// "jsonrpc": "2.0",
/// "result": {
/// "assume_valid_target": "0x0000000000000000000000000000000000000000000000000000000000000000",
/// "assume_valid_target_reached": true,
/// "best_known_block_number": "0x400",
/// "best_known_block_timestamp": "0x5cd2b117",
/// "fast_time": "0x3e8",
/// "ibd": true,
/// "inflight_blocks_count": "0x0",
/// "low_time": "0x5dc",
/// "min_chain_work": "0x3314412053c82802a7",
/// "min_chain_work_reached": true,
/// "normal_time": "0x4e2",
/// "orphan_blocks_count": "0x0",
/// "orphan_blocks_size": "0x0"
Expand Down Expand Up @@ -719,8 +725,21 @@ impl NetRpc for NetRpcImpl {
let state = chain.shared().state();
let (fast_time, normal_time, low_time) = state.read_inflight_blocks().division_point();
let best_known = state.shared_best_header();
let min_chain_work = {
let mut min_chain_work_500k_u128: [u8; 16] = [0; 16];
min_chain_work_500k_u128.copy_from_slice(&MIN_CHAIN_WORK_500K.to_le_bytes()[..16]);
u128::from_le_bytes(min_chain_work_500k_u128)
};
let sync_state = SyncState {
ibd: chain.is_initial_block_download(),
assume_valid_target_reached: state.assume_valid_target().is_none(),
assume_valid_target: state
.assume_valid_target_specified()
.unwrap_or_default()
.pack()
.into(),
min_chain_work: min_chain_work.into(),
min_chain_work_reached: state.min_chain_work_ready(),
best_known_block_number: best_known.number().into(),
best_known_block_timestamp: best_known.timestamp().into(),
orphan_blocks_count: (state.orphan_pool().len() as u64).into(),
Expand Down
25 changes: 24 additions & 1 deletion sync/src/types/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -1290,6 +1290,17 @@ impl SyncShared {
Self::with_tmpdir::<PathBuf>(shared, sync_config, None, tx_relay_receiver)
}

/// Check whether the data already exists in the database before starting
fn check_assume_valid_target_already_exists(sync_config: &SyncConfig, shared: &Shared) -> bool {
if let Some(ref target) = sync_config.assume_valid_target {
if shared.snapshot().block_exists(&target.pack()) {
info!("assume valid target is already in db, CKB will do full verification from now on");
return true;
}
}
false
}

/// Generate a global sync state through configuration
pub fn with_tmpdir<P>(
shared: Shared,
Expand Down Expand Up @@ -1332,7 +1343,14 @@ impl SyncShared {
inflight_blocks: RwLock::new(InflightBlocks::default()),
pending_get_headers: RwLock::new(LruCache::new(GET_HEADERS_CACHE_SIZE)),
tx_relay_receiver,
assume_valid_target: Mutex::new(sync_config.assume_valid_target),
assume_valid_target: Mutex::new({
if Self::check_assume_valid_target_already_exists(&sync_config, &shared) {
None
} else {
sync_config.assume_valid_target.clone()
}
}),
assume_valid_target_specified: sync_config.assume_valid_target,
min_chain_work: sync_config.min_chain_work,
};

Expand Down Expand Up @@ -1693,6 +1711,7 @@ pub struct SyncState {
/* cached for sending bulk */
tx_relay_receiver: Receiver<TxVerificationResult>,
assume_valid_target: Mutex<Option<H256>>,
assume_valid_target_specified: Option<H256>,
min_chain_work: U256,
}

Expand All @@ -1701,6 +1720,10 @@ impl SyncState {
self.assume_valid_target.lock()
}

pub fn assume_valid_target_specified(&self) -> Option<H256> {
self.assume_valid_target_specified.clone()
}

pub fn min_chain_work(&self) -> &U256 {
&self.min_chain_work
}
Expand Down
6 changes: 4 additions & 2 deletions util/app-config/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -31,8 +31,10 @@ use ckb_types::{u256, H256, U256};
use clap::ArgMatches;
use std::{path::PathBuf, str::FromStr};

// 500_000 total difficulty
const MIN_CHAIN_WORK_500K: U256 = u256!("0x3314412053c82802a7");
/// 500_000 total difficulty
///
/// The hexadecimal value "0x3314412053c82802a7" fits within a u128 data type.
pub const MIN_CHAIN_WORK_500K: U256 = u256!("0x3314412053c82802a7");

/// A struct including all the information to start the ckb process.
pub struct Setup {
Expand Down
10 changes: 9 additions & 1 deletion util/jsonrpc-types/src/net.rs
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
use crate::{BlockNumber, Byte32, Timestamp, Uint64};
use crate::{BlockNumber, Byte32, Timestamp, Uint128, Uint64};
use schemars::JsonSchema;
use serde::{Deserialize, Serialize};

Expand Down Expand Up @@ -258,6 +258,14 @@ pub struct SyncState {
/// During IBD, the local node only synchronizes the chain with one selected remote node and
/// stops responding to most P2P requests.
pub ibd: bool,
/// Is ckb reached the assume_valid_target? If no assume_valid_target, this will be true.
pub assume_valid_target_reached: bool,
/// The assume_valid_target specified by ckb, if no assume_valid_target, this will be all zero.
pub assume_valid_target: Byte32,
/// Is ckb reached the MIN_CHAIN_WORK_500K?
pub min_chain_work_reached: bool,
/// The CKB hardcoded MIN_CHAIN_WORK_500K
pub min_chain_work: Uint128,
/// This is the best known block number observed by the local node from the P2P network.
///
/// The best here means that the block leads a chain which has the best known accumulated
Expand Down
12 changes: 1 addition & 11 deletions util/launcher/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -25,7 +25,7 @@ use ckb_rpc::ServiceBuilder;
use ckb_shared::Shared;

use ckb_shared::shared_builder::{SharedBuilder, SharedPackage};
use ckb_store::{ChainDB, ChainStore};
use ckb_store::ChainDB;
use ckb_sync::{BlockFilter, NetTimeProtocol, Relayer, SyncShared, Synchronizer};
use ckb_tx_pool::service::TxVerificationResult;
use ckb_types::prelude::*;
Expand Down Expand Up @@ -215,16 +215,6 @@ impl Launcher {
Ok((shared, pack))
}

/// Check whether the data already exists in the database before starting
pub fn check_assume_valid_target(&mut self, shared: &Shared) {
if let Some(ref target) = self.args.config.network.sync.assume_valid_target {
if shared.snapshot().block_exists(&target.pack()) {
info!("assume valid target is already in db, CKB will do full verification from now on");
self.args.config.network.sync.assume_valid_target.take();
}
}
}

/// Start chain service, return ChainController
pub fn start_chain_service(&self, shared: &Shared, table: ProposalTable) -> ChainController {
let chain_service = ChainService::new(shared.clone(), table);
Expand Down

0 comments on commit a2f860d

Please sign in to comment.