Skip to content

Commit

Permalink
add --limit_load_slot_count_from_snapshot to ledger-tool (#17417)
Browse files Browse the repository at this point in the history
  • Loading branch information
jeffwashington authored May 26, 2021
1 parent bb72ab7 commit 6b9d8d4
Show file tree
Hide file tree
Showing 8 changed files with 32 additions and 2 deletions.
1 change: 1 addition & 0 deletions core/tests/snapshots.rs
Original file line number Diff line number Diff line change
Expand Up @@ -164,6 +164,7 @@ mod tests {
None,
AccountSecondaryIndexes::default(),
false,
None,
)
.unwrap();

Expand Down
13 changes: 13 additions & 0 deletions ledger-tool/src/main.rs
Original file line number Diff line number Diff line change
Expand Up @@ -771,6 +771,12 @@ fn main() {
.validator(is_slot)
.takes_value(true)
.help("Halt processing at the given slot");
let limit_load_slot_count_from_snapshot_arg = Arg::with_name("limit_load_slot_count_from_snapshot")
.long("limit-load-slot-count-from-snapshot")
.value_name("SLOT")
.validator(is_slot)
.takes_value(true)
.help("For debugging and profiling with large snapshots, artificially limit how many slots are loaded from a snapshot.");
let hard_forks_arg = Arg::with_name("hard_forks")
.long("hard-fork")
.value_name("SLOT")
Expand Down Expand Up @@ -1040,6 +1046,7 @@ fn main() {
.arg(&no_snapshot_arg)
.arg(&account_paths_arg)
.arg(&halt_at_slot_arg)
.arg(&limit_load_slot_count_from_snapshot_arg)
.arg(&hard_forks_arg)
.arg(&no_accounts_db_caching_arg)
.arg(&accounts_db_test_hash_calculation_arg)
Expand Down Expand Up @@ -1744,6 +1751,12 @@ fn main() {
poh_verify: !arg_matches.is_present("skip_poh_verify"),
bpf_jit: !matches.is_present("no_bpf_jit"),
accounts_db_caching_enabled: !arg_matches.is_present("no_accounts_db_caching"),
limit_load_slot_count_from_snapshot: value_t!(
arg_matches,
"limit_load_slot_count_from_snapshot",
usize
)
.ok(),
allow_dead_slots: arg_matches.is_present("allow_dead_slots"),
accounts_db_test_hash_calculation: arg_matches
.is_present("accounts_db_test_hash_calculation"),
Expand Down
1 change: 1 addition & 0 deletions ledger/src/bank_forks_utils.rs
Original file line number Diff line number Diff line change
Expand Up @@ -71,6 +71,7 @@ pub fn load(
Some(&crate::builtins::get(process_options.bpf_jit)),
process_options.account_indexes.clone(),
process_options.accounts_db_caching_enabled,
process_options.limit_load_slot_count_from_snapshot,
)
.expect("Load from snapshot failed");
if let Some(shrink_paths) = shrink_paths {
Expand Down
1 change: 1 addition & 0 deletions ledger/src/blockstore_processor.rs
Original file line number Diff line number Diff line change
Expand Up @@ -368,6 +368,7 @@ pub struct ProcessOptions {
pub debug_keys: Option<Arc<HashSet<Pubkey>>>,
pub account_indexes: AccountSecondaryIndexes,
pub accounts_db_caching_enabled: bool,
pub limit_load_slot_count_from_snapshot: Option<usize>,
pub allow_dead_slots: bool,
pub accounts_db_test_hash_calculation: bool,
}
Expand Down
5 changes: 4 additions & 1 deletion runtime/src/accounts_db.rs
Original file line number Diff line number Diff line change
Expand Up @@ -5123,12 +5123,15 @@ impl AccountsDb {
}

#[allow(clippy::needless_collect)]
pub fn generate_index(&self) {
pub fn generate_index(&self, limit_load_slot_count_from_snapshot: Option<usize>) {
type AccountsMap<'a> =
HashMap<Pubkey, (StoredMetaWriteVersion, AppendVecId, StoredAccountMeta<'a>)>;
let mut slots = self.storage.all_slots();
#[allow(clippy::stable_sort_primitive)]
slots.sort();
if let Some(limit) = limit_load_slot_count_from_snapshot {
slots.truncate(limit); // get rid of the newer slots and keep just the older
}
let total_processed_slots_across_all_threads = AtomicU64::new(0);
let outer_slots_len = slots.len();
let chunk_size = (outer_slots_len / 7) + 1; // approximately 400k slots in a snapshot
Expand Down
7 changes: 6 additions & 1 deletion runtime/src/serde_snapshot.rs
Original file line number Diff line number Diff line change
Expand Up @@ -135,6 +135,7 @@ pub(crate) fn bank_from_stream<R>(
additional_builtins: Option<&Builtins>,
account_indexes: AccountSecondaryIndexes,
caching_enabled: bool,
limit_load_slot_count_from_snapshot: Option<usize>,
) -> std::result::Result<Bank, Error>
where
R: Read,
Expand All @@ -154,6 +155,7 @@ where
additional_builtins,
account_indexes,
caching_enabled,
limit_load_slot_count_from_snapshot,
)?;
Ok(bank)
}};
Expand Down Expand Up @@ -243,6 +245,7 @@ fn reconstruct_bank_from_fields<E>(
additional_builtins: Option<&Builtins>,
account_indexes: AccountSecondaryIndexes,
caching_enabled: bool,
limit_load_slot_count_from_snapshot: Option<usize>,
) -> Result<Bank, Error>
where
E: SerializableStorage,
Expand All @@ -254,6 +257,7 @@ where
&genesis_config.cluster_type,
account_indexes,
caching_enabled,
limit_load_slot_count_from_snapshot,
)?;
accounts_db.freeze_accounts(
&Ancestors::from(&bank_fields.ancestors),
Expand All @@ -279,6 +283,7 @@ fn reconstruct_accountsdb_from_fields<E>(
cluster_type: &ClusterType,
account_indexes: AccountSecondaryIndexes,
caching_enabled: bool,
limit_load_slot_count_from_snapshot: Option<usize>,
) -> Result<AccountsDb, Error>
where
E: SerializableStorage,
Expand Down Expand Up @@ -371,6 +376,6 @@ where
accounts_db
.write_version
.fetch_add(version, Ordering::Relaxed);
accounts_db.generate_index();
accounts_db.generate_index(limit_load_slot_count_from_snapshot);
Ok(accounts_db)
}
2 changes: 2 additions & 0 deletions runtime/src/serde_snapshot/tests.rs
Original file line number Diff line number Diff line change
Expand Up @@ -73,6 +73,7 @@ where
&ClusterType::Development,
AccountSecondaryIndexes::default(),
false,
None,
)
}

Expand Down Expand Up @@ -226,6 +227,7 @@ fn test_bank_serialize_style(serde_style: SerdeStyle) {
None,
AccountSecondaryIndexes::default(),
false,
None,
)
.unwrap();
dbank.src = ref_sc;
Expand Down
4 changes: 4 additions & 0 deletions runtime/src/snapshot_utils.rs
Original file line number Diff line number Diff line change
Expand Up @@ -603,6 +603,7 @@ pub fn bank_from_archive<P: AsRef<Path>>(
additional_builtins: Option<&Builtins>,
account_indexes: AccountSecondaryIndexes,
accounts_db_caching_enabled: bool,
limit_load_slot_count_from_snapshot: Option<usize>,
) -> Result<Bank> {
let unpack_dir = tempfile::Builder::new()
.prefix(TMP_SNAPSHOT_PREFIX)
Expand Down Expand Up @@ -633,6 +634,7 @@ pub fn bank_from_archive<P: AsRef<Path>>(
additional_builtins,
account_indexes,
accounts_db_caching_enabled,
limit_load_slot_count_from_snapshot,
)?;

if !bank.verify_snapshot_bank() {
Expand Down Expand Up @@ -791,6 +793,7 @@ fn rebuild_bank_from_snapshots(
additional_builtins: Option<&Builtins>,
account_indexes: AccountSecondaryIndexes,
accounts_db_caching_enabled: bool,
limit_load_slot_count_from_snapshot: Option<usize>,
) -> Result<Bank> {
info!("snapshot version: {}", snapshot_version);

Expand Down Expand Up @@ -826,6 +829,7 @@ fn rebuild_bank_from_snapshots(
additional_builtins,
account_indexes,
accounts_db_caching_enabled,
limit_load_slot_count_from_snapshot,
),
}?)
})?;
Expand Down

0 comments on commit 6b9d8d4

Please sign in to comment.