ledger-tool: Skip compaction in purge command by default (#30891)

Performing a manual ledger compaction can be very time consuming.
Although the compaction will optimize storage use, swapping to skip
compaction favors the command completing faster. Additionally, we no
longer do regular compaction in the validator (via LedgerCleanupService)
and instead make use of range deletion which is much more efficient.

Given the above, this changes alters the default behavior to skip ledger
compaction by default, and introduces a flag should a user really want
to run compaction.
This commit is contained in:
steviez 2023-03-29 10:34:00 -05:00 committed by GitHub
parent bcdf5dad47
commit 86cf0ad758
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
1 changed files with 22 additions and 13 deletions

View File

@ -2323,7 +2323,20 @@ fn main() {
.long("no-compaction") .long("no-compaction")
.required(false) .required(false)
.takes_value(false) .takes_value(false)
.help("Skip ledger compaction after purge") .help("--no-compaction is deprecated, ledger compaction \
after purge is disabled by default")
.conflicts_with("enable_compaction")
.hidden(hidden_unless_forced())
)
.arg(
Arg::with_name("enable_compaction")
.long("enable-compaction")
.required(false)
.takes_value(false)
.help("Perform ledger compaction after purge. Compaction \
will optimize storage space, but may take a long \
time to complete.")
.conflicts_with("no_compaction")
) )
.arg( .arg(
Arg::with_name("dead_slots_only") Arg::with_name("dead_slots_only")
@ -4129,17 +4142,13 @@ fn main() {
("purge", Some(arg_matches)) => { ("purge", Some(arg_matches)) => {
let start_slot = value_t_or_exit!(arg_matches, "start_slot", Slot); let start_slot = value_t_or_exit!(arg_matches, "start_slot", Slot);
let end_slot = value_t!(arg_matches, "end_slot", Slot).ok(); let end_slot = value_t!(arg_matches, "end_slot", Slot).ok();
let no_compaction = arg_matches.is_present("no_compaction"); let perform_compaction = arg_matches.is_present("enable_compaction");
let dead_slots_only = arg_matches.is_present("dead_slots_only"); let dead_slots_only = arg_matches.is_present("dead_slots_only");
let batch_size = value_t_or_exit!(arg_matches, "batch_size", usize); let batch_size = value_t_or_exit!(arg_matches, "batch_size", usize);
let access_type = if !no_compaction {
AccessType::Primary
} else {
AccessType::PrimaryForMaintenance
};
let blockstore = open_blockstore( let blockstore = open_blockstore(
&ledger_path, &ledger_path,
access_type, AccessType::PrimaryForMaintenance,
wal_recovery_mode, wal_recovery_mode,
force_update_to_open, force_update_to_open,
); );
@ -4167,19 +4176,19 @@ fn main() {
exit(1); exit(1);
} }
info!( info!(
"Purging data from slots {} to {} ({} slots) (skip compaction: {}) (dead slot only: {})", "Purging data from slots {} to {} ({} slots) (do compaction: {}) (dead slot only: {})",
start_slot, start_slot,
end_slot, end_slot,
end_slot - start_slot, end_slot - start_slot,
no_compaction, perform_compaction,
dead_slots_only, dead_slots_only,
); );
let purge_from_blockstore = |start_slot, end_slot| { let purge_from_blockstore = |start_slot, end_slot| {
blockstore.purge_from_next_slots(start_slot, end_slot); blockstore.purge_from_next_slots(start_slot, end_slot);
if no_compaction { if perform_compaction {
blockstore.purge_slots(start_slot, end_slot, PurgeType::Exact);
} else {
blockstore.purge_and_compact_slots(start_slot, end_slot); blockstore.purge_and_compact_slots(start_slot, end_slot);
} else {
blockstore.purge_slots(start_slot, end_slot, PurgeType::Exact);
} }
}; };
if !dead_slots_only { if !dead_slots_only {