From d4cb1b84329e395b330cf360e4fd982142167fde Mon Sep 17 00:00:00 2001 From: Nazar Mokrynskyi Date: Fri, 17 Jun 2022 22:18:12 +0300 Subject: [PATCH] Fix archiver restart, simplify logic a bit --- crates/sc-consensus-subspace/src/archiver.rs | 77 +++++++++++--------- 1 file changed, 41 insertions(+), 36 deletions(-) diff --git a/crates/sc-consensus-subspace/src/archiver.rs b/crates/sc-consensus-subspace/src/archiver.rs index ff15eb71d6..c6df274718 100644 --- a/crates/sc-consensus-subspace/src/archiver.rs +++ b/crates/sc-consensus-subspace/src/archiver.rs @@ -116,9 +116,12 @@ where Some((last_root_block, last_archived_block, block_object_mappings)) } -struct BlockHashesToArchive { - block_hashes: Vec, - best_archived: Option, +struct BlockHashesToArchive +where + Block: BlockT, +{ + block_hashes: Vec, + best_archived: Option<(Block::Hash, NumberFor)>, } fn block_hashes_to_archive( @@ -126,7 +129,7 @@ fn block_hashes_to_archive( best_block_hash: Block::Hash, blocks_to_archive_from: NumberFor, blocks_to_archive_to: NumberFor, -) -> BlockHashesToArchive +) -> BlockHashesToArchive where Block: BlockT, Client: HeaderBackend, @@ -146,7 +149,7 @@ where block_hashes.push(block_hash_to_check); if best_archived.is_none() { - best_archived.replace(block_hash_to_check); + best_archived.replace((block_hash_to_check, *header.number())); } } @@ -163,11 +166,14 @@ where } } -struct InitializedArchiver { +struct InitializedArchiver +where + Block: BlockT, +{ confirmation_depth_k: BlockNumber, archiver: Archiver, older_archived_segments: Vec, - best_archived_block_hash: Option, + best_archived_block: (Block::Hash, NumberFor), } fn initialize_archiver( @@ -175,7 +181,7 @@ fn initialize_archiver( best_block_number: NumberFor, subspace_link: &SubspaceLink, client: &Client, -) -> InitializedArchiver +) -> InitializedArchiver where Block: BlockT, Client: ProvideRuntimeApi + BlockBackend + HeaderBackend, @@ -202,6 +208,7 @@ where let maybe_last_archived_block = find_last_archived_block(client, best_block_id); let have_last_root_block = maybe_last_archived_block.is_some(); + let mut best_archived_block = None; let mut archiver = if let Some((last_root_block, last_archived_block, block_object_mappings)) = maybe_last_archived_block @@ -214,6 +221,13 @@ where last_archived_block_number, ); + // Set initial value, this is needed in case only genesis block was archived and there is + // nothing else available + best_archived_block.replace(( + last_archived_block.block.hash(), + *last_archived_block.block.header().number(), + )); + Archiver::with_initial_state( record_size as usize, recorded_history_segment_size as usize, @@ -230,7 +244,6 @@ where }; let mut older_archived_segments = Vec::new(); - let mut best_archived_block_hash = None; // Process blocks since last fully archived block (or genesis) up to the current head minus K { @@ -269,7 +282,7 @@ where blocks_to_archive_from.into(), blocks_to_archive_to.into(), ); - best_archived_block_hash = block_hashes_to_archive.best_archived; + best_archived_block = block_hashes_to_archive.best_archived; let block_hashes_to_archive = block_hashes_to_archive.block_hashes; for block_hash_to_archive in block_hashes_to_archive.into_iter().rev() { @@ -330,7 +343,8 @@ where confirmation_depth_k, archiver, older_archived_segments, - best_archived_block_hash, + best_archived_block: best_archived_block + .expect("Must always set if there is no logical error; qed"), } } @@ -360,7 +374,7 @@ pub fn start_subspace_archiver( confirmation_depth_k, mut archiver, older_archived_segments, - mut best_archived_block_hash, + best_archived_block: (mut best_archived_block_hash, mut best_archived_block_number), } = initialize_archiver( best_block_hash, best_block_number, @@ -391,9 +405,6 @@ pub fn start_subspace_archiver( drop(older_archived_segments); } - let mut last_archived_block_number = - archiver.last_archived_block_number().map(Into::into); - while let Some(ImportedBlockNotification { block_number, mut root_block_sender, @@ -407,17 +418,13 @@ pub fn start_subspace_archiver( } }; - if let Some(last_archived_block) = &mut last_archived_block_number { - if *last_archived_block >= block_number_to_archive { - // This block was already archived, skip - continue; - } - - *last_archived_block = block_number_to_archive; - } else { - last_archived_block_number.replace(block_number_to_archive); + if best_archived_block_number >= block_number_to_archive { + // This block was already archived, skip + continue; } + best_archived_block_number = block_number_to_archive; + let block = client .block(&BlockId::Number(block_number_to_archive)) .expect("Older block by number must always exist") @@ -433,20 +440,18 @@ pub fn start_subspace_archiver( block_hash_to_archive ); - if let Some(best_archived_block_hash) = best_archived_block_hash { - if parent_block_hash != best_archived_block_hash { - error!( - target: "subspace", - "Attempt to switch to a different fork beyond archiving depth, \ - can't do it: parent block hash {}, best archived block hash {}", - parent_block_hash, - best_archived_block_hash - ); - return; - } + if parent_block_hash != best_archived_block_hash { + error!( + target: "subspace", + "Attempt to switch to a different fork beyond archiving depth, \ + can't do it: parent block hash {}, best archived block hash {}", + parent_block_hash, + best_archived_block_hash + ); + return; } - best_archived_block_hash.replace(block_hash_to_archive); + best_archived_block_hash = block_hash_to_archive; let block_object_mappings = client .runtime_api()