Skip to content
This repository has been archived by the owner on Nov 15, 2023. It is now read-only.

Commit

Permalink
Add target to SyncState enum variants and add is_major_syncing meth…
Browse files Browse the repository at this point in the history
…od on it
  • Loading branch information
nazar-pc committed Sep 6, 2022
1 parent 912eb7a commit 03df7d5
Show file tree
Hide file tree
Showing 5 changed files with 51 additions and 54 deletions.
64 changes: 29 additions & 35 deletions client/informant/src/display.rs
Original file line number Diff line number Diff line change
Expand Up @@ -93,43 +93,37 @@ impl<B: BlockT> InformantDisplay<B> {
(diff_bytes_inbound, diff_bytes_outbound)
};

let (level, status, target) = match (
net_status.sync_state,
net_status.best_seen_block,
net_status.state_sync,
net_status.warp_sync,
) {
(
_,
_,
_,
Some(WarpSyncProgress { phase: WarpSyncPhase::DownloadingBlocks(n), .. }),
) => ("⏩", "Block history".into(), format!(", #{}", n)),
(_, _, _, Some(warp)) => (
"⏩",
"Warping".into(),
format!(
", {}, {:.2} Mib",
warp.phase,
(warp.total_bytes as f32) / (1024f32 * 1024f32)
let (level, status, target) =
match (net_status.sync_state, net_status.state_sync, net_status.warp_sync) {
(
_,
_,
Some(WarpSyncProgress { phase: WarpSyncPhase::DownloadingBlocks(n), .. }),
) => ("⏩", "Block history".into(), format!(", #{}", n)),
(_, _, Some(warp)) => (
"⏩",
"Warping".into(),
format!(
", {}, {:.2} Mib",
warp.phase,
(warp.total_bytes as f32) / (1024f32 * 1024f32)
),
),
),
(_, _, Some(state), _) => (
"⚙️ ",
"Downloading state".into(),
format!(
", {}%, {:.2} Mib",
state.percentage,
(state.size as f32) / (1024f32 * 1024f32)
(_, Some(state), _) => (
"⚙️ ",
"Downloading state".into(),
format!(
", {}%, {:.2} Mib",
state.percentage,
(state.size as f32) / (1024f32 * 1024f32)
),
),
),
(SyncState::Idle, _, _, _) => ("💤", "Idle".into(), "".into()),
(SyncState::Downloading, None, _, _) =>
("⚙️ ", format!("Preparing{}", speed), "".into()),
(SyncState::Downloading, Some(n), _, _) =>
("⚙️ ", format!("Syncing{}", speed), format!(", target=#{}", n)),
(SyncState::Importing, _, _, _) => ("⚙️ ", format!("Importing{}", speed), "".into()),
};
(SyncState::Idle, _, _) => ("💤", "Idle".into(), "".into()),
(SyncState::Downloading { target }, _, _) =>
("⚙️ ", format!("Syncing{}", speed), format!(", target=#{target}")),
(SyncState::Importing { target }, _, _) =>
("⚙️ ", format!("Preparing{}", speed), format!(", target=#{target}")),
};

if self.format.enable_color {
info!(
Expand Down
2 changes: 1 addition & 1 deletion client/network/common/src/service.rs
Original file line number Diff line number Diff line change
Expand Up @@ -97,7 +97,7 @@ where
#[derive(Clone)]
pub struct NetworkStatus<B: BlockT> {
/// Current global sync state.
pub sync_state: SyncState,
pub sync_state: SyncState<NumberFor<B>>,
/// Target sync block number.
pub best_seen_block: Option<NumberFor<B>>,
/// Number of peers participating in syncing.
Expand Down
17 changes: 11 additions & 6 deletions client/network/common/src/sync.rs
Original file line number Diff line number Diff line change
Expand Up @@ -44,13 +44,20 @@ pub struct PeerInfo<Block: BlockT> {

/// Reported sync state.
#[derive(Clone, Eq, PartialEq, Debug)]
pub enum SyncState {
pub enum SyncState<BlockNumber> {
/// Initial sync is complete, keep-up sync is active.
Idle,
/// Actively catching up with the chain.
Downloading,
Downloading { target: BlockNumber },
/// All blocks are downloaded and are being imported.
Importing,
Importing { target: BlockNumber },
}

impl<BlockNumber> SyncState<BlockNumber> {
/// Are we actively catching up with the chain?
pub fn is_major_syncing(&self) -> bool {
!matches!(self, SyncState::Idle)
}
}

/// Reported state download progress.
Expand All @@ -66,11 +73,9 @@ pub struct StateDownloadProgress {
#[derive(Clone)]
pub struct SyncStatus<Block: BlockT> {
/// Current global sync state.
pub state: SyncState,
pub state: SyncState<NumberFor<Block>>,
/// Target sync block number.
pub best_seen_block: Option<NumberFor<Block>>,
/// Are we actively catching up with the chain?
pub is_major_syncing: bool,
/// Number of peers participating in syncing.
pub num_peers: u32,
/// Number of blocks queued for import
Expand Down
3 changes: 2 additions & 1 deletion client/network/src/service.rs
Original file line number Diff line number Diff line change
Expand Up @@ -1943,7 +1943,8 @@ where
.behaviour_mut()
.user_protocol_mut()
.sync_state()
.is_major_syncing;
.state
.is_major_syncing();

this.tx_handler_controller.set_gossip_enabled(!is_major_syncing);

Expand Down
19 changes: 8 additions & 11 deletions client/network/sync/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -392,17 +392,17 @@ where
let median_seen = self.median_seen();
let best_seen_block =
median_seen.and_then(|median| (median > self.best_queued_number).then_some(median));
let sync_state = if let Some(n) = best_seen_block.or(median_seen) {
let sync_state = if let Some(target) = median_seen {
// A chain is classified as downloading if the provided best block is
// more than `MAJOR_SYNC_BLOCKS` behind the best block or as importing
// if the same can be said about queued blocks.
let best_block = self.client.info().best_number;
if n > best_block && n - best_block > MAJOR_SYNC_BLOCKS.into() {
if target > best_block && target - best_block > MAJOR_SYNC_BLOCKS.into() {
// If target is not queued, we're downloading, otherwise importing.
if n > self.best_queued_number {
SyncState::Downloading
if target > self.best_queued_number {
SyncState::Downloading { target }
} else {
SyncState::Importing
SyncState::Importing { target }
}
} else {
SyncState::Idle
Expand All @@ -422,12 +422,9 @@ where
_ => None,
};

let is_major_syncing = !matches!(sync_state, SyncState::Idle);

SyncStatus {
state: sync_state,
best_seen_block,
is_major_syncing,
num_peers: self.peers.len() as u32,
queued_blocks: self.queue_blocks.len() as u32,
state_sync: self.state_sync.as_ref().map(|s| s.progress()),
Expand Down Expand Up @@ -681,7 +678,7 @@ where
trace!(target: "sync", "Too many blocks in the queue.");
return Box::new(std::iter::empty())
}
let major_sync = self.status().state == SyncState::Downloading;
let is_major_syncing = self.status().state.is_major_syncing();
let attrs = self.required_block_attributes();
let blocks = &mut self.blocks;
let fork_targets = &mut self.fork_targets;
Expand All @@ -691,7 +688,7 @@ where
let client = &self.client;
let queue = &self.queue_blocks;
let allowed_requests = self.allowed_requests.take();
let max_parallel = if major_sync { 1 } else { self.max_parallel_downloads };
let max_parallel = if is_major_syncing { 1 } else { self.max_parallel_downloads };
let gap_sync = &mut self.gap_sync;
let iter = self.peers.iter_mut().filter_map(move |(id, peer)| {
if !peer.state.is_available() || !allowed_requests.contains(id) {
Expand Down Expand Up @@ -1782,7 +1779,7 @@ where
);
}

let origin = if !gap && self.status().state != SyncState::Downloading {
let origin = if !gap && !self.status().state.is_major_syncing() {
BlockOrigin::NetworkBroadcast
} else {
BlockOrigin::NetworkInitialSync
Expand Down

0 comments on commit 03df7d5

Please sign in to comment.