allow to pass trusted node sync options during BN startup (#5545)

Using trusted node sync currently requires to run two commands -
first the `trustedNodeSync` command to initialize the database,
followed by the regular startup command to continue syncing.

The `trustedNodeSync` options are now also available during regular
startup, and are used when the database is empty to simplify setting up
a new Nimbus beacon node. This also aligns behaviour closer with other
Ethereum consensus implementations.

The new logic only applies if the database has not yet been initialized;
same as before. Also, the database needs to be removed under the same
conditions as before when a fresh sync is desired.
This commit is contained in:
Etan Kissling 2023-11-03 16:07:49 +01:00 committed by GitHub
parent c95f9feec4
commit 29fe958908
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
4 changed files with 87 additions and 4 deletions

View File

@ -339,16 +339,27 @@ type
desc: "Weak subjectivity checkpoint in the format block_root:epoch_number" desc: "Weak subjectivity checkpoint in the format block_root:epoch_number"
name: "weak-subjectivity-checkpoint" .}: Option[Checkpoint] name: "weak-subjectivity-checkpoint" .}: Option[Checkpoint]
externalBeaconApiUrl* {.
desc: "External beacon API to use for syncing (on empty database)"
name: "external-beacon-api-url" .}: Option[string]
syncLightClient* {. syncLightClient* {.
desc: "Accelerate execution layer sync using light client" desc: "Accelerate sync using light client"
defaultValue: true defaultValue: true
name: "sync-light-client" .}: bool name: "sync-light-client" .}: bool
trustedBlockRoot* {. trustedBlockRoot* {.
hidden desc: "Recent trusted finalized block root to sync from external " &
desc: "Recent trusted finalized block root to initialize light client from" "beacon API (with `--external-beacon-api-url`). " &
"Uses the light client sync protocol to obtain the latest " &
"finalized checkpoint (LC is initialized from trusted block root)"
name: "trusted-block-root" .}: Option[Eth2Digest] name: "trusted-block-root" .}: Option[Eth2Digest]
trustedStateRoot* {.
desc: "Recent trusted finalized state root to sync from external " &
"beacon API (with `--external-beacon-api-url`)"
name: "trusted-state-root" .}: Option[Eth2Digest]
finalizedCheckpointState* {. finalizedCheckpointState* {.
desc: "SSZ file specifying a recent finalized state" desc: "SSZ file specifying a recent finalized state"
name: "finalized-checkpoint-state" .}: Option[InputFile] name: "finalized-checkpoint-state" .}: Option[InputFile]

View File

@ -555,6 +555,26 @@ proc init*(T: type BeaconNode,
) )
db = BeaconChainDB.new(config.databaseDir, cfg, inMemory = false) db = BeaconChainDB.new(config.databaseDir, cfg, inMemory = false)
if config.externalBeaconApiUrl.isSome and ChainDAGRef.isInitialized(db).isErr:
if config.trustedStateRoot.isNone and config.trustedBlockRoot.isNone:
warn "Ignoring `--external-beacon-api-url`, neither " &
"`--trusted-block-root` nor `--trusted-state-root` are provided",
externalBeaconApiUrl = config.externalBeaconApiUrl.get,
trustedBlockRoot = config.trustedBlockRoot,
trustedStateRoot = config.trustedStateRoot
else:
await db.doRunTrustedNodeSync(
metadata,
config.databaseDir,
config.eraDir,
config.externalBeaconApiUrl.get,
config.trustedStateRoot.map do (x: Eth2Digest) -> string:
"0x" & x.data.toHex,
config.trustedBlockRoot,
backfill = false,
reindex = false,
downloadDepositSnapshot = false)
if config.finalizedCheckpointBlock.isSome: if config.finalizedCheckpointBlock.isSome:
warn "--finalized-checkpoint-block has been deprecated, ignoring" warn "--finalized-checkpoint-block has been deprecated, ignoring"

View File

@ -66,7 +66,13 @@ The following options are available:
seen by other nodes it communicates with. This option allows to enable/disable seen by other nodes it communicates with. This option allows to enable/disable
this functionality [=false]. this functionality [=false].
--weak-subjectivity-checkpoint Weak subjectivity checkpoint in the format block_root:epoch_number. --weak-subjectivity-checkpoint Weak subjectivity checkpoint in the format block_root:epoch_number.
--sync-light-client Accelerate execution layer sync using light client [=true]. --external-beacon-api-url External beacon API to use for syncing (on empty database).
--sync-light-client Accelerate sync using light client [=true].
--trusted-block-root Recent trusted finalized block root to sync from external beacon API (with
`--external-beacon-api-url`). Uses the light client sync protocol to obtain the
latest finalized checkpoint (LC is initialized from trusted block root).
--trusted-state-root Recent trusted finalized state root to sync from external beacon API (with
`--external-beacon-api-url`).
--finalized-checkpoint-state SSZ file specifying a recent finalized state. --finalized-checkpoint-state SSZ file specifying a recent finalized state.
--genesis-state SSZ file specifying the genesis state of the network (for networks without a --genesis-state SSZ file specifying the genesis state of the network (for networks without a
built-in genesis state). built-in genesis state).

View File

@ -82,3 +82,49 @@ More information is available from the [options](./options.md) page.
## Keep track of your sync progress ## Keep track of your sync progress
See [here](./keep-an-eye.md#keep-track-of-your-syncing-progress) for how to keep track of your sync progress. See [here](./keep-an-eye.md#keep-track-of-your-syncing-progress) for how to keep track of your sync progress.
## Checkpoint sync
!!! note ""
This feature is available from `v23.11.0` onwards.
You can use an existing synced node or a third-party service to accelerate sync significantly. Instead of downloading and verifying the entire blockchain, you can point Nimbus to a trusted block.
!!! warning
Selecting a block from an untrusted source or using an outdated block or state may lead to Nimbus syncing to an unexpected state. Especially when [running a validator](./run-a-validator.md), it is vital to pick a recent trusted block for checkpoint sync, and to verify that Nimbus is synced to the correct state before starting validator duties.
!!! note
The Nimbus database must be empty to use checkpoint sync. When using a pre-existing database, checkpoint sync options are ignored.
!!! tip
A list of community-operated checkpoint sync nodes can be found [here](https://eth-clients.github.io/checkpoint-sync-endpoints/).
To use checkpoint sync, run the following commands (inserting the checkpoint sync endpoint and your own trusted block root):
=== "Holesky"
```sh
CHECKPOINT_SYNC_ENDPOINT=http://127.0.0.1:8551
TRUSTED_BLOCK_ROOT=0x1234567890123456789012345678901234567890123456789012345678901234
./run-holesky-beacon-node.sh \
--external-beacon-api-url=$CHECKPOINT_SYNC_ENDPOINT \
--trusted-block-root=$TRUSTED_BLOCK_ROOT
```
=== "Mainnet"
```sh
TRUSTED_BLOCK_ROOT=0x1234567890123456789012345678901234567890123456789012345678901234
./run-mainnet-beacon-node.sh \
--external-beacon-api-url=$CHECKPOINT_SYNC_ENDPOINT \
--trusted-block-root=$TRUSTED_BLOCK_ROOT
```
The following [configuration options](./options.md) control checkpoint sync behaviour:
| Option | Description |
|------------------------------------------|-------------|
| <nobr>`--external-beacon-api-url`</nobr> | <ul><li>External beacon API to use for checkpoint sync</li></ul> |
| <nobr>`--trusted-block-root`</nobr> | <ul><li>Recent trusted finalized block root to sync from external beacon API</li><li>Uses the [light client sync protocol](https://github.com/ethereum/consensus-specs/blob/v1.4.0-beta.3/specs/altair/light-client/sync-protocol.md) to obtain the latest finalized checkpoint</li></ul> |
| <nobr>`--trusted-state-root`</nobr> | <ul><li>Recent trusted finalized state root to sync from external beacon API</li><li>Takes precedence over `--trusted-block-root` if both are specified</li></ul> |
!!! info
If the external beacon API does not support serving [light client data](./light-client-data.md), use the `--trusted-state-root` option instead of `--trusted-block-root`.