Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Hierarchical state diffs #5978

Merged
merged 71 commits into from
Nov 18, 2024
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
71 commits
Select commit Hold shift + click to select a range
ec974b8
Start extracting freezer changes for tree-states
michaelsproul Jun 21, 2024
df5e716
Remove unused config args
dapplion Jun 21, 2024
17ce7d0
Add comments
dapplion Jun 21, 2024
3c5d722
Remove unwraps
dapplion Jun 21, 2024
31bcd84
Subjective more clear implementation
dapplion Jun 21, 2024
394abba
Clean up hdiff
michaelsproul Jul 2, 2024
cac7672
Update xdelta3
michaelsproul Jul 4, 2024
b87c6bb
Tree states archive metrics (#6040)
dapplion Jul 4, 2024
e578f5d
Port and clean up forwards iterator changes
michaelsproul Jul 5, 2024
bdcc818
Add and polish hierarchy-config flag
michaelsproul Jul 5, 2024
1501ba5
Merge remote-tracking branch 'origin/unstable' into tree-states-archive
michaelsproul Jul 5, 2024
aba6b8b
Cleaner errors
michaelsproul Jul 5, 2024
420e524
Fix beacon_chain test compilation
michaelsproul Jul 5, 2024
3bec78b
Merge remote-tracking branch 'origin/unstable' into tree-states-archive
michaelsproul Jul 9, 2024
0500e64
Patch a few more freezer block roots
michaelsproul Jul 9, 2024
2715f60
Fix genesis block root bug
michaelsproul Jul 11, 2024
fa1a941
Fix test failing due to pending updates
michaelsproul Jul 12, 2024
ee032df
Beacon chain tests passing
michaelsproul Jul 16, 2024
8b7b362
Merge remote-tracking branch 'origin/unstable' into tree-states-archive
michaelsproul Jul 16, 2024
3f87cd8
Merge remote-tracking branch 'origin/unstable' into tree-states-archive
michaelsproul Jul 29, 2024
d2049ca
Fix doc lint
michaelsproul Jul 29, 2024
57b73df
Implement DB schema upgrade for hierarchical state diffs (#6193)
dapplion Aug 19, 2024
71738b8
Merge remote-tracking branch 'origin/unstable' into tree-states-archive
michaelsproul Aug 19, 2024
17985a6
Fix test compilation
michaelsproul Aug 19, 2024
b2f785a
Update schema downgrade test
michaelsproul Aug 19, 2024
7789725
Fix tests
michaelsproul Aug 19, 2024
a4582c5
Fix null anchor migration
michaelsproul Aug 26, 2024
c8cea79
Merge remote-tracking branch 'origin/unstable' into tree-states-archive
michaelsproul Sep 2, 2024
47afa49
Fix tree states upgrade migration (#6328)
michaelsproul Sep 3, 2024
1e6b2d6
Clean hdiff CLI flag and metrics
michaelsproul Sep 5, 2024
45a0762
Fix "staged reconstruction"
michaelsproul Sep 9, 2024
ca7a7d7
Merge remote-tracking branch 'origin/unstable' into tree-states-archive
michaelsproul Sep 9, 2024
e00f639
Fix alloy issues
michaelsproul Sep 9, 2024
907a7c0
Fix staged reconstruction logic
michaelsproul Sep 9, 2024
024843e
Prevent weird slot drift
michaelsproul Sep 9, 2024
bdf04c8
Remove "allow" flag
michaelsproul Sep 9, 2024
2d9ce8f
Update CLI help
michaelsproul Sep 9, 2024
9de88fd
Remove FIXME about downgrade
michaelsproul Sep 9, 2024
05f93dd
Merge remote-tracking branch 'origin/unstable' into tree-states-archive
michaelsproul Sep 11, 2024
8a50f2a
Remove some unnecessary error variants
michaelsproul Sep 11, 2024
bcbf9b8
Fix new test
michaelsproul Sep 11, 2024
cf75901
Tree states archive - review comments and metrics (#6386)
dapplion Sep 16, 2024
dbd52f3
Update beacon_node/store/src/hot_cold_store.rs
michaelsproul Sep 16, 2024
5d3a83d
Merge remote-tracking branch 'origin/unstable' into tree-states-archive
michaelsproul Sep 16, 2024
3d90ac6
Clarify comment and remove anchor_slot garbage
michaelsproul Sep 16, 2024
1890278
Simplify database anchor (#6397)
michaelsproul Sep 19, 2024
f6118d2
Merge remote-tracking branch 'origin/unstable' into tree-states-archive
michaelsproul Sep 19, 2024
5d69f9c
Merge remote-tracking branch 'origin/unstable' into tree-states-archive
michaelsproul Sep 24, 2024
b66aa9a
More metrics
michaelsproul Sep 27, 2024
a33130a
Merge remote-tracking branch 'origin/unstable' into tree-states-archive
michaelsproul Oct 8, 2024
ab9c275
New historic state cache (#6475)
michaelsproul Oct 16, 2024
e87a618
Update database docs
michaelsproul Oct 18, 2024
62ee6af
Update diagram
michaelsproul Oct 21, 2024
f36f49b
Merge remote-tracking branch 'origin/unstable' into tree-states-archive
michaelsproul Oct 21, 2024
9405faa
Update lockbud to work with bindgen/etc
michaelsproul Oct 21, 2024
a69ce78
Correct pkg name for Debian
michaelsproul Oct 21, 2024
237de37
Remove vestigial epochs_per_state_diff
michaelsproul Oct 28, 2024
ddf7f9c
Merge remote-tracking branch 'origin/unstable' into tree-states-archive
michaelsproul Oct 28, 2024
5b43b99
Markdown lint
michaelsproul Oct 28, 2024
d4f23e0
Merge remote-tracking branch 'origin/unstable' into tree-states-archive
michaelsproul Oct 29, 2024
c4d6ef3
Address Jimmy's review comments
michaelsproul Oct 31, 2024
f6412f3
Simplify ReplayFrom case
michaelsproul Oct 31, 2024
6c32733
Fix and document genesis_state_root
michaelsproul Oct 31, 2024
f8a80dc
Typo
michaelsproul Oct 31, 2024
f5b42e2
Merge branch 'unstable' into tree-states-archive
jimmygchen Oct 31, 2024
b14a924
Compute diff of validators list manually (#6556)
dapplion Nov 14, 2024
dc2b665
Test hdiff binary format stability (#6585)
michaelsproul Nov 16, 2024
fa79803
Merge remote-tracking branch 'origin/unstable' into tree-states-archive
michaelsproul Nov 18, 2024
6b6f796
Add deprecation warning for SPRP
michaelsproul Nov 18, 2024
9b4b069
Update xdelta to get rid of duplicate deps
michaelsproul Nov 18, 2024
b0a5bbe
Document test
michaelsproul Nov 18, 2024
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
383 changes: 307 additions & 76 deletions Cargo.lock

Large diffs are not rendered by default.

2 changes: 2 additions & 0 deletions Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -237,6 +237,8 @@ unused_port = { path = "common/unused_port" }
validator_client = { path = "validator_client" }
validator_dir = { path = "common/validator_dir" }
warp_utils = { path = "common/warp_utils" }
xdelta3 = { git = "http://github.com/michaelsproul/xdelta3-rs", rev="ae9a1d2585ef998f4656acdc35cf263ee88e6dfa" }
zstd = "0.13"

[profile.maxperf]
inherits = "release"
Expand Down
24 changes: 10 additions & 14 deletions beacon_node/beacon_chain/src/beacon_chain.rs
Original file line number Diff line number Diff line change
Expand Up @@ -779,7 +779,6 @@ impl<T: BeaconChainTypes> BeaconChain<T> {
start_slot,
local_head.beacon_state.clone(),
local_head.beacon_block_root,
&self.spec,
)?;

Ok(iter.map(|result| result.map_err(Into::into)))
Expand All @@ -804,12 +803,11 @@ impl<T: BeaconChainTypes> BeaconChain<T> {
}

self.with_head(move |head| {
let iter = self.store.forwards_block_roots_iterator_until(
start_slot,
end_slot,
|| Ok((head.beacon_state.clone(), head.beacon_block_root)),
&self.spec,
)?;
let iter =
self.store
.forwards_block_roots_iterator_until(start_slot, end_slot, || {
Ok((head.beacon_state.clone(), head.beacon_block_root))
})?;
Ok(iter
.map(|result| result.map_err(Into::into))
.take_while(move |result| {
Expand Down Expand Up @@ -879,7 +877,6 @@ impl<T: BeaconChainTypes> BeaconChain<T> {
start_slot,
local_head.beacon_state_root(),
local_head.beacon_state.clone(),
&self.spec,
)?;

Ok(iter.map(|result| result.map_err(Into::into)))
Expand All @@ -896,12 +893,11 @@ impl<T: BeaconChainTypes> BeaconChain<T> {
end_slot: Slot,
) -> Result<impl Iterator<Item = Result<(Hash256, Slot), Error>> + '_, Error> {
self.with_head(move |head| {
let iter = self.store.forwards_state_roots_iterator_until(
start_slot,
end_slot,
|| Ok((head.beacon_state.clone(), head.beacon_state_root())),
&self.spec,
)?;
let iter =
self.store
.forwards_state_roots_iterator_until(start_slot, end_slot, || {
Ok((head.beacon_state.clone(), head.beacon_state_root()))
})?;
Ok(iter
.map(|result| result.map_err(Into::into))
.take_while(move |result| {
Expand Down
7 changes: 6 additions & 1 deletion beacon_node/beacon_chain/src/migrate.rs
Original file line number Diff line number Diff line change
Expand Up @@ -24,6 +24,10 @@ const MAX_COMPACTION_PERIOD_SECONDS: u64 = 604800;
const MIN_COMPACTION_PERIOD_SECONDS: u64 = 7200;
/// Compact after a large finality gap, if we respect `MIN_COMPACTION_PERIOD_SECONDS`.
const COMPACTION_FINALITY_DISTANCE: u64 = 1024;
/// Maximum number of blocks applied in each reconstruction burst.
///
/// This limits the amount of time that the finalization migration is paused for.
const BLOCKS_PER_RECONSTRUCTION: usize = 8192 * 4;

/// Default number of epochs to wait between finalization migrations.
pub const DEFAULT_EPOCHS_PER_MIGRATION: u64 = 1;
Expand Down Expand Up @@ -201,7 +205,8 @@ impl<E: EthSpec, Hot: ItemStore<E>, Cold: ItemStore<E>> BackgroundMigrator<E, Ho
}

pub fn run_reconstruction(db: Arc<HotColdDB<E, Hot, Cold>>, log: &Logger) {
if let Err(e) = db.reconstruct_historic_states() {
// FIXME(sproul): still need to port more changes here
if let Err(e) = db.reconstruct_historic_states(Some(BLOCKS_PER_RECONSTRUCTION)) {
error!(
log,
"State reconstruction failed";
Expand Down
29 changes: 1 addition & 28 deletions beacon_node/beacon_chain/src/schema_change.rs
Original file line number Diff line number Diff line change
@@ -1,7 +1,4 @@
//! Utilities for managing database schema changes.
mod migration_schema_v17;
mod migration_schema_v18;
mod migration_schema_v19;

use crate::beacon_chain::BeaconChainTypes;
use crate::types::ChainSpec;
Expand Down Expand Up @@ -52,32 +49,8 @@ pub fn migrate_schema<T: BeaconChainTypes>(
}

//
// Migrations from before SchemaVersion(16) are deprecated.
// Migrations from before SchemaVersion(19) are deprecated.
//
(SchemaVersion(16), SchemaVersion(17)) => {
let ops = migration_schema_v17::upgrade_to_v17::<T>(db.clone(), log)?;
db.store_schema_version_atomically(to, ops)
}
(SchemaVersion(17), SchemaVersion(16)) => {
let ops = migration_schema_v17::downgrade_from_v17::<T>(db.clone(), log)?;
db.store_schema_version_atomically(to, ops)
}
(SchemaVersion(17), SchemaVersion(18)) => {
let ops = migration_schema_v18::upgrade_to_v18::<T>(db.clone(), log)?;
db.store_schema_version_atomically(to, ops)
}
(SchemaVersion(18), SchemaVersion(17)) => {
let ops = migration_schema_v18::downgrade_from_v18::<T>(db.clone(), log)?;
db.store_schema_version_atomically(to, ops)
}
(SchemaVersion(18), SchemaVersion(19)) => {
let ops = migration_schema_v19::upgrade_to_v19::<T>(db.clone(), log)?;
db.store_schema_version_atomically(to, ops)
}
(SchemaVersion(19), SchemaVersion(18)) => {
let ops = migration_schema_v19::downgrade_from_v19::<T>(db.clone(), log)?;
db.store_schema_version_atomically(to, ops)
}
// Anything else is an error.
(_, _) => Err(HotColdDBError::UnsupportedSchemaVersion {
target_version: to,
Expand Down
88 changes: 0 additions & 88 deletions beacon_node/beacon_chain/src/schema_change/migration_schema_v17.rs

This file was deleted.

119 changes: 0 additions & 119 deletions beacon_node/beacon_chain/src/schema_change/migration_schema_v18.rs

This file was deleted.

65 changes: 0 additions & 65 deletions beacon_node/beacon_chain/src/schema_change/migration_schema_v19.rs

This file was deleted.

Loading