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

Modularize beacon node backend #4718

Merged
merged 133 commits into from
Jan 23, 2025
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
133 commits
Select commit Hold shift + click to select a range
0487b33
add interface
eserilev Aug 31, 2023
4b48ef8
Merge branch 'unstable' of https://github.com/sigp/lighthouse into mo…
eserilev Aug 31, 2023
ec84723
level db interface updates
eserilev Sep 6, 2023
86b820e
level db interface updates
eserilev Sep 6, 2023
846b213
starting the split
eserilev Sep 7, 2023
a885c62
remove leveldb references
eserilev Sep 9, 2023
b8636d1
get test cases to pass
eserilev Sep 9, 2023
7177f22
refactor and get test cases to pass
eserilev Sep 9, 2023
d86eaf3
generalize key iter
eserilev Sep 10, 2023
d6c4971
resolve merge conflicts
eserilev Jan 30, 2024
2ee7279
rename impl to LevelDB
eserilev Jan 30, 2024
cc1dcf4
initial work
eserilev Jan 30, 2024
b6a2823
write option
eserilev Jan 30, 2024
3881da1
cfg
eserilev Jan 30, 2024
1d39785
merge
eserilev Jan 30, 2024
04011f3
redb db impl
eserilev Jan 30, 2024
e2ecb41
redb
eserilev Jan 30, 2024
323e9a9
durability and atomicity
eserilev Jan 30, 2024
e2a9f7c
Merge branch 'beacon-node-backend-redb' into modularize-beacon-node-b…
eserilev Jan 30, 2024
ad24ec9
remove savepoint
eserilev Jan 31, 2024
3e557d6
Merge branch 'beacon-node-backend-redb' into modularize-beacon-node-b…
eserilev Jan 31, 2024
39c6b83
working on getting full_participation_no_skips test to pass
eserilev Jan 31, 2024
f718f9f
test case passes
eserilev Feb 1, 2024
41700d6
update
eserilev Feb 1, 2024
04eada1
use rw lock
eserilev Feb 1, 2024
e4d47ea
table iter experiment
eserilev Feb 2, 2024
4cf145d
iterator tests
eserilev Feb 3, 2024
01f8d3d
redb 2.0
eserilev Feb 3, 2024
22cb4c0
iter_column_keys
eserilev Feb 3, 2024
27e9128
remove generic type param
eserilev Feb 3, 2024
82ed22d
test cases passing
eserilev Feb 3, 2024
f96ea2a
iter temp and iter raw impl
eserilev Feb 3, 2024
1583a1f
remove unneeded get_key_for_col
eserilev Feb 3, 2024
715e24d
fix
eserilev Feb 3, 2024
5dab93b
lint
eserilev Feb 3, 2024
114c7dd
remove unwraps
eserilev Feb 4, 2024
b84ff3c
fmt
eserilev Feb 4, 2024
6badfe6
redb dependency
eserilev Feb 4, 2024
a76f64f
Merge branch 'unstable' of https://github.com/sigp/lighthouse into mo…
eserilev Feb 8, 2024
ae6bf24
add db name
eserilev Feb 9, 2024
795859e
resolve merge conflicts
eserilev Feb 10, 2024
ab5e6a8
merge conflicts resolved
eserilev Feb 10, 2024
9f4ccb5
dir check
eserilev Feb 19, 2024
5b49e4f
Merge branch 'unstable' of https://github.com/sigp/lighthouse into mo…
eserilev Feb 19, 2024
487c2f1
logging errors
eserilev Feb 19, 2024
fd60c5b
Merge branch 'unstable' of https://github.com/sigp/lighthouse into mo…
eserilev Feb 22, 2024
e1ab17d
consolidate iter_raw to generic iter
eserilev Feb 24, 2024
ceeded2
Merge branch 'unstable' of https://github.com/sigp/lighthouse into mo…
eserilev Feb 24, 2024
2bb1be7
linting
eserilev Feb 24, 2024
b1c437d
off by one column iter
eserilev Feb 24, 2024
0c6352b
fix test
eserilev Feb 25, 2024
69f315f
remove iter_temp_state_roots, add predicate, add backend flag
eserilev Feb 27, 2024
969b679
added redb and leveldb build feature
eserilev Feb 27, 2024
ddb68e2
update docket
eserilev Feb 27, 2024
304aed9
resolve merge conflict
eserilev Mar 28, 2024
de444ee
resolve merge conflicts, move redb to v2.0
eserilev Mar 29, 2024
48c5ca4
merge unstable
eserilev Jun 6, 2024
577836c
fmt fmt fmt
eserilev Jun 6, 2024
d067bc6
resolve merge conflicts
eserilev Aug 12, 2024
bdcdbda
remote iter raw keys
eserilev Aug 12, 2024
ad7f889
fix failed test
eserilev Aug 13, 2024
acfcd55
fmt
eserilev Aug 13, 2024
1164ddd
cargo changes
eserilev Aug 13, 2024
def8b6c
Merge branch 'modularize-beacon-node-backend' of https://github.com/e…
eserilev Aug 13, 2024
f7fc0a0
defeault to redb
eserilev Aug 14, 2024
e1806d8
defeault to redb
eserilev Aug 14, 2024
2d2d4e9
Merge branch 'unstable' of https://github.com/sigp/lighthouse into mo…
eserilev Aug 14, 2024
fdbe248
Merge branch 'unstable' of https://github.com/sigp/lighthouse into mo…
eserilev Aug 20, 2024
0b3eee2
revert forced redb
eserilev Aug 20, 2024
15569b7
rename dbfile to .redb
eserilev Aug 20, 2024
72d56ec
fix test, update docs
eserilev Aug 20, 2024
e9ee3ba
fix leveldb error
eserilev Aug 21, 2024
2494a08
fmt
eserilev Aug 21, 2024
58d0baf
leveldb fix
eserilev Aug 21, 2024
ced1189
remove println
eserilev Aug 21, 2024
ec7059b
remove extraneous migration schemas and comment tuples
eserilev Aug 26, 2024
ad7db41
add compaction metrics
eserilev Aug 26, 2024
8ed2ff4
log from_ssz_bytes error in lc server
eserilev Aug 26, 2024
63b15b1
add additional metrics
eserilev Aug 26, 2024
fc2e412
linting
eserilev Aug 26, 2024
74e1c07
fixbroken test
eserilev Aug 26, 2024
72b6381
metrics
eserilev Aug 27, 2024
627f013
fix build error
eserilev Aug 27, 2024
6237531
small revert
eserilev Aug 27, 2024
df59d23
resolve merge conflicts:
eserilev Aug 29, 2024
d97aeaf
Merge branch 'modularize-beacon-node-backend' of https://github.com/e…
eserilev Aug 29, 2024
0bab63c
update metrics
eserilev Aug 29, 2024
06490d4
fix redb
eserilev Aug 29, 2024
89866f2
fix conflicts, add TODOS
eserilev Sep 9, 2024
f2c514a
Merge branch 'modularize-beacon-node-backend' of https://github.com/e…
eserilev Sep 9, 2024
7428536
remove todos
eserilev Sep 9, 2024
910f45d
fix audits
eserilev Sep 9, 2024
cf3b056
conflicts
eserilev Sep 10, 2024
b589e2d
resolve conflicts, add some TODOs
eserilev Sep 10, 2024
e3cdca5
Merge branch 'unstable' of https://github.com/sigp/lighthouse into mo…
eserilev Sep 16, 2024
282aa16
update redb version to 2.1.3
eserilev Sep 16, 2024
807137a
get tests to pass
eserilev Sep 16, 2024
4b7a4ff
Merge branch 'unstable' of https://github.com/sigp/lighthouse into mo…
eserilev Sep 19, 2024
7bcc6f4
Merge branch 'unstable' of https://github.com/sigp/lighthouse into mo…
eserilev Sep 20, 2024
921dbae
Merge remote-tracking branch 'origin/unstable' into modularize-beacon…
michaelsproul Oct 29, 2024
23b0a7c
Merge branch 'unstable' of https://github.com/sigp/lighthouse into mo…
eserilev Nov 1, 2024
be5ceec
optimize redb temp state cleanup
eserilev Nov 2, 2024
5e7ff6e
fix tests
eserilev Nov 2, 2024
c83812b
fix test
eserilev Nov 4, 2024
eda7aef
delete while fn to iterate through blobs and prune
eserilev Nov 5, 2024
b11ce93
linting
eserilev Nov 18, 2024
9863c71
cleanup
eserilev Nov 18, 2024
4f80f27
resolve merge conflicts
eserilev Nov 18, 2024
d53c5ff
fmt
eserilev Nov 18, 2024
c938048
fix test
eserilev Nov 18, 2024
4a46aed
fix blob and column logic
eserilev Nov 21, 2024
28925dc
Merge branch 'unstable' of https://github.com/sigp/lighthouse into mo…
eserilev Dec 1, 2024
6dfd984
more widespread usage of DBColumn
eserilev Dec 1, 2024
7ac9460
Merge branch 'modularize-beacon-node-backend' of https://github.com/e…
eserilev Dec 1, 2024
d3e8216
Merge remote-tracking branch 'origin/unstable' into modularize-beacon…
michaelsproul Dec 3, 2024
ced0e07
Add missing plumbing for backend CLI flag
michaelsproul Dec 3, 2024
6d8898a
add beacon node backend flag to db manager
eserilev Dec 4, 2024
8565c77
add beacon node backend flag to db manager
eserilev Dec 4, 2024
ec20adf
add beacon node backend flag to db manager
eserilev Dec 4, 2024
2512fed
Add delete_while to leveldb
eserilev Jan 7, 2025
c179254
Cargo sort
eserilev Jan 7, 2025
bbdcbdd
update wordlist and md file
eserilev Jan 8, 2025
ddf0ebc
Merge remote-tracking branch 'origin/unstable' into modularize-beacon…
michaelsproul Jan 20, 2025
9a0b920
rename to delete_if
eserilev Jan 20, 2025
1f02130
Merge branch 'modularize-beacon-node-backend' of https://github.com/e…
eserilev Jan 20, 2025
1b31492
Re-delete OTB verification service
michaelsproul Jan 21, 2025
1feac02
Remove directory detection for Redb
michaelsproul Jan 22, 2025
9f971eb
Delete `iter_raw_entries`
michaelsproul Jan 22, 2025
6bb73b9
Cosmetic fixes from review
michaelsproul Jan 22, 2025
ed9d347
Avoid holding block cache lock during blob pruning
michaelsproul Jan 22, 2025
d79cb2e
Refactor iter_column and iter_column_from
eserilev Jan 22, 2025
40ff310
Merge branch 'modularize-beacon-node-backend' of https://github.com/e…
eserilev Jan 22, 2025
33f3262
Fix tests
eserilev Jan 22, 2025
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
2 changes: 2 additions & 0 deletions Cargo.lock

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

2 changes: 1 addition & 1 deletion Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,7 @@ BUILD_PATH_AARCH64 = "target/$(AARCH64_TAG)/release"
PINNED_NIGHTLY ?= nightly

# List of features to use when cross-compiling. Can be overridden via the environment.
CROSS_FEATURES ?= gnosis,slasher-lmdb,slasher-mdbx,slasher-redb,jemalloc
CROSS_FEATURES ?= gnosis,slasher-lmdb,slasher-mdbx,slasher-redb,jemalloc,beacon-node-leveldb,beacon-node-redb

# Cargo profile for Cross builds. Default is for local builds, CI uses an override.
CROSS_PROFILE ?= release
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -317,7 +317,6 @@ impl<E: EthSpec> PendingComponents<E> {
None,
)
};

let executed_block = recover(diet_executed_block)?;

let AvailabilityPendingExecutedBlock {
Expand Down Expand Up @@ -732,7 +731,7 @@ mod test {
use slog::{info, Logger};
use state_processing::ConsensusContext;
use std::collections::VecDeque;
use store::{HotColdDB, ItemStore, LevelDB, StoreConfig};
use store::{database::interface::BeaconNodeBackend, HotColdDB, ItemStore, StoreConfig};
use tempfile::{tempdir, TempDir};
use types::non_zero_usize::new_non_zero_usize;
use types::{ExecPayload, MinimalEthSpec};
Expand All @@ -744,7 +743,7 @@ mod test {
db_path: &TempDir,
spec: Arc<ChainSpec>,
log: Logger,
) -> Arc<HotColdDB<E, LevelDB<E>, LevelDB<E>>> {
) -> Arc<HotColdDB<E, BeaconNodeBackend<E>, BeaconNodeBackend<E>>> {
let hot_path = db_path.path().join("hot_db");
let cold_path = db_path.path().join("cold_db");
let blobs_path = db_path.path().join("blobs_db");
Expand Down Expand Up @@ -920,7 +919,11 @@ mod test {
)
where
E: EthSpec,
T: BeaconChainTypes<HotStore = LevelDB<E>, ColdStore = LevelDB<E>, EthSpec = E>,
T: BeaconChainTypes<
HotStore = BeaconNodeBackend<E>,
ColdStore = BeaconNodeBackend<E>,
EthSpec = E,
>,
{
let log = test_logger();
let chain_db_path = tempdir().expect("should get temp dir");
Expand Down
11 changes: 5 additions & 6 deletions beacon_node/beacon_chain/src/historical_blocks.rs
Original file line number Diff line number Diff line change
Expand Up @@ -10,10 +10,7 @@ use std::borrow::Cow;
use std::iter;
use std::time::Duration;
use store::metadata::DataColumnInfo;
use store::{
get_key_for_col, AnchorInfo, BlobInfo, DBColumn, Error as StoreError, KeyValueStore,
KeyValueStoreOp,
};
use store::{AnchorInfo, BlobInfo, DBColumn, Error as StoreError, KeyValueStore, KeyValueStoreOp};
use strum::IntoStaticStr;
use types::{FixedBytesExtended, Hash256, Slot};

Expand Down Expand Up @@ -153,7 +150,8 @@ impl<T: BeaconChainTypes> BeaconChain<T> {
// Store block roots, including at all skip slots in the freezer DB.
for slot in (block.slot().as_u64()..prev_block_slot.as_u64()).rev() {
cold_batch.push(KeyValueStoreOp::PutKeyValue(
get_key_for_col(DBColumn::BeaconBlockRoots.into(), &slot.to_be_bytes()),
DBColumn::BeaconBlockRoots,
slot.to_be_bytes().to_vec(),
block_root.as_slice().to_vec(),
));
}
Expand All @@ -169,7 +167,8 @@ impl<T: BeaconChainTypes> BeaconChain<T> {
let genesis_slot = self.spec.genesis_slot;
for slot in genesis_slot.as_u64()..prev_block_slot.as_u64() {
cold_batch.push(KeyValueStoreOp::PutKeyValue(
get_key_for_col(DBColumn::BeaconBlockRoots.into(), &slot.to_be_bytes()),
DBColumn::BeaconBlockRoots,
slot.to_be_bytes().to_vec(),
self.genesis_block_root.as_slice().to_vec(),
));
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -3,9 +3,7 @@ use crate::validator_pubkey_cache::DatabasePubkey;
use slog::{info, Logger};
use ssz::{Decode, Encode};
use std::sync::Arc;
use store::{
get_key_for_col, DBColumn, Error, HotColdDB, KeyValueStore, KeyValueStoreOp, StoreItem,
};
use store::{DBColumn, Error, HotColdDB, KeyValueStore, KeyValueStoreOp, StoreItem};
use types::{Hash256, PublicKey};

const LOG_EVERY: usize = 200_000;
Expand Down Expand Up @@ -62,9 +60,9 @@ pub fn downgrade_from_v21<T: BeaconChainTypes>(
message: format!("{e:?}"),
})?;

let db_key = get_key_for_col(DBColumn::PubkeyCache.into(), key.as_slice());
ops.push(KeyValueStoreOp::PutKeyValue(
db_key,
DBColumn::PubkeyCache,
key.as_slice().to_vec(),
pubkey_bytes.as_ssz_bytes(),
));

Expand Down
17 changes: 6 additions & 11 deletions beacon_node/beacon_chain/src/schema_change/migration_schema_v22.rs
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,6 @@ use std::sync::Arc;
use store::chunked_iter::ChunkedVectorIter;
use store::{
chunked_vector::BlockRootsChunked,
get_key_for_col,
metadata::{
SchemaVersion, ANCHOR_FOR_ARCHIVE_NODE, ANCHOR_UNINITIALIZED, STATE_UPPER_LIMIT_NO_RETAIN,
},
Expand All @@ -21,7 +20,7 @@ fn load_old_schema_frozen_state<T: BeaconChainTypes>(
) -> Result<Option<BeaconState<T::EthSpec>>, Error> {
let Some(partial_state_bytes) = db
.cold_db
.get_bytes(DBColumn::BeaconState.into(), state_root.as_slice())?
.get_bytes(DBColumn::BeaconState, state_root.as_slice())?
else {
return Ok(None);
};
Expand Down Expand Up @@ -136,10 +135,7 @@ pub fn delete_old_schema_freezer_data<T: BeaconChainTypes>(
for column in columns {
for res in db.cold_db.iter_column_keys::<Vec<u8>>(column) {
let key = res?;
cold_ops.push(KeyValueStoreOp::DeleteKey(get_key_for_col(
column.as_str(),
&key,
)));
cold_ops.push(KeyValueStoreOp::DeleteKey(column, key));
}
}
let delete_ops = cold_ops.len();
Expand Down Expand Up @@ -175,7 +171,8 @@ pub fn write_new_schema_block_roots<T: BeaconChainTypes>(
// Store the genesis block root if it would otherwise not be stored.
if oldest_block_slot != 0 {
cold_ops.push(KeyValueStoreOp::PutKeyValue(
get_key_for_col(DBColumn::BeaconBlockRoots.into(), &0u64.to_be_bytes()),
DBColumn::BeaconBlockRoots,
0u64.to_be_bytes().to_vec(),
genesis_block_root.as_slice().to_vec(),
));
}
Expand All @@ -192,10 +189,8 @@ pub fn write_new_schema_block_roots<T: BeaconChainTypes>(
// OK to hold these in memory (10M slots * 43 bytes per KV ~= 430 MB).
for (i, (slot, block_root)) in block_root_iter.enumerate() {
cold_ops.push(KeyValueStoreOp::PutKeyValue(
get_key_for_col(
DBColumn::BeaconBlockRoots.into(),
&(slot as u64).to_be_bytes(),
),
DBColumn::BeaconBlockRoots,
slot.to_be_bytes().to_vec(),
block_root.as_slice().to_vec(),
));

Expand Down
15 changes: 11 additions & 4 deletions beacon_node/beacon_chain/src/test_utils.rs
Original file line number Diff line number Diff line change
Expand Up @@ -56,7 +56,8 @@ use std::str::FromStr;
use std::sync::atomic::{AtomicUsize, Ordering};
use std::sync::{Arc, LazyLock};
use std::time::Duration;
use store::{config::StoreConfig, HotColdDB, ItemStore, LevelDB, MemoryStore};
use store::database::interface::BeaconNodeBackend;
use store::{config::StoreConfig, HotColdDB, ItemStore, MemoryStore};
use task_executor::TaskExecutor;
use task_executor::{test_utils::TestRuntime, ShutdownReason};
use tree_hash::TreeHash;
Expand Down Expand Up @@ -116,7 +117,7 @@ pub fn get_kzg(spec: &ChainSpec) -> Arc<Kzg> {
pub type BaseHarnessType<E, THotStore, TColdStore> =
Witness<TestingSlotClock, CachingEth1Backend<E>, E, THotStore, TColdStore>;

pub type DiskHarnessType<E> = BaseHarnessType<E, LevelDB<E>, LevelDB<E>>;
pub type DiskHarnessType<E> = BaseHarnessType<E, BeaconNodeBackend<E>, BeaconNodeBackend<E>>;
pub type EphemeralHarnessType<E> = BaseHarnessType<E, MemoryStore<E>, MemoryStore<E>>;

pub type BoxedMutator<E, Hot, Cold> = Box<
Expand Down Expand Up @@ -299,7 +300,10 @@ impl<E: EthSpec> Builder<EphemeralHarnessType<E>> {

impl<E: EthSpec> Builder<DiskHarnessType<E>> {
/// Disk store, start from genesis.
pub fn fresh_disk_store(mut self, store: Arc<HotColdDB<E, LevelDB<E>, LevelDB<E>>>) -> Self {
pub fn fresh_disk_store(
mut self,
store: Arc<HotColdDB<E, BeaconNodeBackend<E>, BeaconNodeBackend<E>>>,
) -> Self {
let validator_keypairs = self
.validator_keypairs
.clone()
Expand All @@ -324,7 +328,10 @@ impl<E: EthSpec> Builder<DiskHarnessType<E>> {
}

/// Disk store, resume.
pub fn resumed_disk_store(mut self, store: Arc<HotColdDB<E, LevelDB<E>, LevelDB<E>>>) -> Self {
pub fn resumed_disk_store(
mut self,
store: Arc<HotColdDB<E, BeaconNodeBackend<E>, BeaconNodeBackend<E>>>,
) -> Self {
let mutator = move |builder: BeaconChainBuilder<_>| {
builder
.resume_from_db()
Expand Down
5 changes: 3 additions & 2 deletions beacon_node/beacon_chain/tests/op_verification.rs
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,8 @@ use state_processing::per_block_processing::errors::{
AttesterSlashingInvalid, BlockOperationError, ExitInvalid, ProposerSlashingInvalid,
};
use std::sync::{Arc, LazyLock};
use store::{LevelDB, StoreConfig};
use store::database::interface::BeaconNodeBackend;
use store::StoreConfig;
use tempfile::{tempdir, TempDir};
use types::*;

Expand All @@ -26,7 +27,7 @@ static KEYPAIRS: LazyLock<Vec<Keypair>> =

type E = MinimalEthSpec;
type TestHarness = BeaconChainHarness<DiskHarnessType<E>>;
type HotColdDB = store::HotColdDB<E, LevelDB<E>, LevelDB<E>>;
type HotColdDB = store::HotColdDB<E, BeaconNodeBackend<E>, BeaconNodeBackend<E>>;

fn get_store(db_path: &TempDir) -> Arc<HotColdDB> {
let spec = Arc::new(test_spec::<E>());
Expand Down
17 changes: 10 additions & 7 deletions beacon_node/beacon_chain/tests/store_tests.rs
Original file line number Diff line number Diff line change
Expand Up @@ -25,10 +25,11 @@ use std::collections::HashSet;
use std::convert::TryInto;
use std::sync::{Arc, LazyLock};
use std::time::Duration;
use store::database::interface::BeaconNodeBackend;
use store::metadata::{SchemaVersion, CURRENT_SCHEMA_VERSION, STATE_UPPER_LIMIT_NO_RETAIN};
use store::{
iter::{BlockRootsIterator, StateRootsIterator},
BlobInfo, DBColumn, HotColdDB, LevelDB, StoreConfig,
BlobInfo, DBColumn, HotColdDB, StoreConfig,
};
use tempfile::{tempdir, TempDir};
use tokio::time::sleep;
Expand All @@ -46,15 +47,15 @@ static KEYPAIRS: LazyLock<Vec<Keypair>> =
type E = MinimalEthSpec;
type TestHarness = BeaconChainHarness<DiskHarnessType<E>>;

fn get_store(db_path: &TempDir) -> Arc<HotColdDB<E, LevelDB<E>, LevelDB<E>>> {
fn get_store(db_path: &TempDir) -> Arc<HotColdDB<E, BeaconNodeBackend<E>, BeaconNodeBackend<E>>> {
get_store_generic(db_path, StoreConfig::default(), test_spec::<E>())
}

fn get_store_generic(
db_path: &TempDir,
config: StoreConfig,
spec: ChainSpec,
) -> Arc<HotColdDB<E, LevelDB<E>, LevelDB<E>>> {
) -> Arc<HotColdDB<E, BeaconNodeBackend<E>, BeaconNodeBackend<E>>> {
let hot_path = db_path.path().join("chain_db");
let cold_path = db_path.path().join("freezer_db");
let blobs_path = db_path.path().join("blobs_db");
Expand All @@ -73,7 +74,7 @@ fn get_store_generic(
}

fn get_harness(
store: Arc<HotColdDB<E, LevelDB<E>, LevelDB<E>>>,
store: Arc<HotColdDB<E, BeaconNodeBackend<E>, BeaconNodeBackend<E>>>,
validator_count: usize,
) -> TestHarness {
// Most tests expect to retain historic states, so we use this as the default.
Expand All @@ -85,7 +86,7 @@ fn get_harness(
}

fn get_harness_generic(
store: Arc<HotColdDB<E, LevelDB<E>, LevelDB<E>>>,
store: Arc<HotColdDB<E, BeaconNodeBackend<E>, BeaconNodeBackend<E>>>,
validator_count: usize,
chain_config: ChainConfig,
) -> TestHarness {
Expand Down Expand Up @@ -244,7 +245,6 @@ async fn full_participation_no_skips() {
AttestationStrategy::AllValidators,
)
.await;

check_finalization(&harness, num_blocks_produced);
check_split_slot(&harness, store);
check_chain_dump(&harness, num_blocks_produced + 1);
Expand Down Expand Up @@ -3508,7 +3508,10 @@ fn check_finalization(harness: &TestHarness, expected_slot: u64) {
}

/// Check that the HotColdDB's split_slot is equal to the start slot of the last finalized epoch.
fn check_split_slot(harness: &TestHarness, store: Arc<HotColdDB<E, LevelDB<E>, LevelDB<E>>>) {
fn check_split_slot(
harness: &TestHarness,
store: Arc<HotColdDB<E, BeaconNodeBackend<E>, BeaconNodeBackend<E>>>,
) {
let split_slot = store.get_split_slot();
assert_eq!(
harness
Expand Down
5 changes: 3 additions & 2 deletions beacon_node/client/src/builder.rs
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,7 @@ use beacon_chain::{
eth1_chain::{CachingEth1Backend, Eth1Chain},
slot_clock::{SlotClock, SystemTimeSlotClock},
state_advance_timer::spawn_state_advance_timer,
store::{HotColdDB, ItemStore, LevelDB, StoreConfig},
store::{HotColdDB, ItemStore, StoreConfig},
BeaconChain, BeaconChainTypes, Eth1ChainBackend, MigratorConfig, ServerSentEventHandler,
};
use beacon_chain::{Kzg, LightClientProducerEvent};
Expand All @@ -41,6 +41,7 @@ use std::path::{Path, PathBuf};
use std::sync::Arc;
use std::time::Duration;
use std::time::{SystemTime, UNIX_EPOCH};
use store::database::interface::BeaconNodeBackend;
use timer::spawn_timer;
use tokio::sync::oneshot;
use types::{
Expand Down Expand Up @@ -1030,7 +1031,7 @@ where
}

impl<TSlotClock, TEth1Backend, E>
ClientBuilder<Witness<TSlotClock, TEth1Backend, E, LevelDB<E>, LevelDB<E>>>
ClientBuilder<Witness<TSlotClock, TEth1Backend, E, BeaconNodeBackend<E>, BeaconNodeBackend<E>>>
where
TSlotClock: SlotClock + 'static,
TEth1Backend: Eth1ChainBackend<E> + 'static,
Expand Down
4 changes: 1 addition & 3 deletions beacon_node/http_api/tests/tests.rs
Original file line number Diff line number Diff line change
Expand Up @@ -1933,7 +1933,7 @@ impl ApiTester {
.sync_committee_period(&self.chain.spec)
.unwrap();

let result = match self
match self
.client
.get_beacon_light_client_updates::<E>(current_sync_committee_period, 1)
.await
Expand All @@ -1954,7 +1954,6 @@ impl ApiTester {
.unwrap();

assert_eq!(1, expected.len());
michaelsproul marked this conversation as resolved.
Show resolved Hide resolved
assert_eq!(result.clone().unwrap().len(), expected.len());
self
}

Expand All @@ -1979,7 +1978,6 @@ impl ApiTester {
.get_light_client_bootstrap(&self.chain.store, &block_root, 1u64, &self.chain.spec);

assert!(expected.is_ok());

assert_eq!(result.unwrap().data, expected.unwrap().unwrap().0);

self
Expand Down
9 changes: 9 additions & 0 deletions beacon_node/src/cli.rs
Original file line number Diff line number Diff line change
Expand Up @@ -1591,5 +1591,14 @@ pub fn cli_app() -> Command {
.action(ArgAction::Set)
.display_order(0)
)
.arg(
Arg::new("beacon-node-backend")
.long("beacon-node-backend")
.value_name("DATABASE")
.value_parser(store::config::DatabaseBackend::VARIANTS.to_vec())
.help("Set the database backend to be used by the beacon node.")
.action(ArgAction::Set)
.display_order(0)
)
.group(ArgGroup::new("enable_http").args(["http", "gui", "staking"]).multiple(true))
}
4 changes: 4 additions & 0 deletions beacon_node/src/config.rs
Original file line number Diff line number Diff line change
Expand Up @@ -432,6 +432,10 @@ pub fn get_config<E: EthSpec>(
warn!(log, "The slots-per-restore-point flag is deprecated");
}

if let Some(backend) = clap_utils::parse_optional(cli_args, "beacon-node-backend")? {
client_config.store.backend = backend;
}

if let Some(hierarchy_config) = clap_utils::parse_optional(cli_args, "hierarchy-exponents")? {
client_config.store.hierarchy_config = hierarchy_config;
}
Expand Down
Loading
Loading