diff --git a/ledger-tool/src/bigtable.rs b/ledger-tool/src/bigtable.rs index aa52ee705cc646..bac7b6cdddfc09 100644 --- a/ledger-tool/src/bigtable.rs +++ b/ledger-tool/src/bigtable.rs @@ -25,6 +25,7 @@ use { UiTransactionEncoding, }, std::{ + cmp::min, collections::HashSet, path::Path, process::exit, @@ -36,7 +37,7 @@ use { async fn upload( blockstore: Blockstore, - starting_slot: Slot, + mut starting_slot: Slot, ending_slot: Option, force_reupload: bool, config: solana_storage_bigtable::LedgerStorageConfig, @@ -49,19 +50,29 @@ async fn upload( force_reupload, ..ConfirmedBlockUploadConfig::default() }; + let blockstore = Arc::new(blockstore); + + let ending_slot = ending_slot.unwrap_or_else(|| blockstore.last_root()); - solana_ledger::bigtable_upload::upload_confirmed_blocks( - Arc::new(blockstore), - bigtable, - starting_slot, - ending_slot, - config, - Arc::new(AtomicBool::new(false)), - ) - .await - .map(|last_slot_uploaded| { + while starting_slot <= ending_slot { + let current_ending_slot = min( + ending_slot, + starting_slot.saturating_add(config.max_num_slots_to_check as u64 * 2), + ); + let last_slot_uploaded = solana_ledger::bigtable_upload::upload_confirmed_blocks( + blockstore.clone(), + bigtable.clone(), + starting_slot, + current_ending_slot, + config.clone(), + Arc::new(AtomicBool::new(false)), + ) + .await?; info!("last slot uploaded: {}", last_slot_uploaded); - }) + starting_slot = last_slot_uploaded.saturating_add(1); + } + info!("No more blocks to upload."); + Ok(()) } async fn delete_slots( diff --git a/ledger/src/bigtable_upload.rs b/ledger/src/bigtable_upload.rs index f1145a4eef8245..0c8cfd47fec530 100644 --- a/ledger/src/bigtable_upload.rs +++ b/ledger/src/bigtable_upload.rs @@ -45,7 +45,7 @@ pub async fn upload_confirmed_blocks( blockstore: Arc, bigtable: solana_storage_bigtable::LedgerStorage, starting_slot: Slot, - ending_slot: Option, + ending_slot: Slot, config: ConfirmedBlockUploadConfig, exit: Arc, ) -> Result> { @@ -60,14 +60,7 @@ pub async fn upload_confirmed_blocks( starting_slot, err ) })? - .map_while(|slot| { - if let Some(ending_slot) = &ending_slot { - if slot > *ending_slot { - return None; - } - } - Some(slot) - }) + .map_while(|slot| (slot <= ending_slot).then(|| slot)) .collect(); if blockstore_slots.is_empty() { diff --git a/ledger/src/bigtable_upload_service.rs b/ledger/src/bigtable_upload_service.rs index 192783c9b71acb..22d149d3249b10 100644 --- a/ledger/src/bigtable_upload_service.rs +++ b/ledger/src/bigtable_upload_service.rs @@ -102,7 +102,7 @@ impl BigTableUploadService { blockstore.clone(), bigtable_ledger_storage.clone(), start_slot, - Some(end_slot), + end_slot, config.clone(), exit.clone(), ));