mirror of
https://github.com/status-im/nimbus-eth2.git
synced 2025-01-09 13:56:23 +00:00
update EIP4844 related light client sync docs (#4538)
Further clarify why it is okay to drop blobs during LC based sync.
This commit is contained in:
parent
f8ee0def2b
commit
a57cec56cb
@ -1479,43 +1479,18 @@ proc installMessageValidators(node: BeaconNode) =
|
|||||||
# is not sufficient for that (as of Capella); it is also required to
|
# is not sufficient for that (as of Capella); it is also required to
|
||||||
# provide the full `ExecutionPayload` via `engine_newPayload`.
|
# provide the full `ExecutionPayload` via `engine_newPayload`.
|
||||||
#
|
#
|
||||||
# Therefore, blocks gossip is followed even while DAG is out of sync,
|
# Because sync committees sign the parent beacon block, observed
|
||||||
# but it is not routed to `node.processor[]` in that situation
|
# blocks need to be cached in `node.optimisticProcessor` until a
|
||||||
# to avoid filling up the quarantine with a ton of missing block
|
# matching `sync_aggregate` is obtained from a followup block.
|
||||||
# requests (the entire diff between LC head and DAG head). The routing
|
# A valid `sync_aggregate` is considered good enough to optimistically
|
||||||
# is controlled by having `shouldSyncOptimistically` return true.
|
# trigger EL sync. Note that only new heads are provided to the EL
|
||||||
#
|
# optimistically; finality is always sourced from the DAG.
|
||||||
# Because sync committees sign the parent beacon block root,
|
|
||||||
# and we cannot meaningfully validate blocks due to lack of
|
|
||||||
# `BeaconState` and validator public keys, we pass them into
|
|
||||||
# `node.optimisticProcessor` where they are cached in RAM.
|
|
||||||
# As soon as we find a matching `sync_aggregate` with sync committee
|
|
||||||
# signatures, that block is then passed to the EL as sync target
|
|
||||||
# via `engine_newPayload` and `engine_forkchoiceUpdate`.
|
|
||||||
# Note that only new heads are provided; finality is always from DAG.
|
|
||||||
# The sync aggregate can be understood as a delegated consensus
|
|
||||||
# verification by the sync committee based on honest majority.
|
|
||||||
#
|
#
|
||||||
# With EIP4844, blobs are paired with beacon blocks.
|
# With EIP4844, blobs are paired with beacon blocks.
|
||||||
# The assumption is that it is alright to simply discard the blob and
|
# The blob is not relevant for triggering sync on the EL; therefore,
|
||||||
# trigger a sync via `engine_newPayload` / `engine_forkchoiceUpdated`
|
# it is discarded here. The blob is re-obtained once the main DAG
|
||||||
# without providing a blob in `engine_newPayload`. The blob would
|
# sufficiently catches up, and then passed into `node.processor[]`
|
||||||
# later be provided through another `engine_newPayload`, when the
|
# when `shouldSyncOptimistically` flips to `false`.
|
||||||
# main beacon node sync catches up to wall clock. The sync committee
|
|
||||||
# only signs the beacon block root, not the blob.
|
|
||||||
#
|
|
||||||
# Ideally, we do not even want to subscribe to blocks gossip to
|
|
||||||
# trigger an EL sync. This can be revisited once the EL block header
|
|
||||||
# accumulators (`txs_root`, `withdrawals_root`, maybe `receipts_root`)
|
|
||||||
# have been adjusted to be derivable from `ExecutionPayloadHeader`
|
|
||||||
# which we receive via light client protocol (from Capella onward).
|
|
||||||
# With those fields derivable, a new `engine_newPayloadHeader` API
|
|
||||||
# could be introduced to support syncing to new target block without
|
|
||||||
# blocks gossip subscription (and without passing the blob for sure).
|
|
||||||
#
|
|
||||||
# Until then, keep this workaround present (and if `newPayload` turns
|
|
||||||
# out to not work properly without the blob, revisit this section to
|
|
||||||
# also cache the blob in memory until sync aggregate is available).
|
|
||||||
toValidationResult(
|
toValidationResult(
|
||||||
node.optimisticProcessor.processSignedBeaconBlock(
|
node.optimisticProcessor.processSignedBeaconBlock(
|
||||||
signedBlock.beacon_block))
|
signedBlock.beacon_block))
|
||||||
|
Loading…
x
Reference in New Issue
Block a user