From c9667f83997047a00db659f0a0d4e1a4bccfd965 Mon Sep 17 00:00:00 2001 From: Jordan Hrycaj Date: Mon, 13 Jan 2025 10:21:51 +0000 Subject: [PATCH] Removed obsolete `finalHash` and `final` block number maintenance why: Not needed anymore, `forkChoice()` as has been integrated into `importBlock()`. --- nimbus/beacon/api_handler/api_forkchoice.nim | 2 +- nimbus/common/common.nim | 6 +-- nimbus/sync/beacon/README.md | 4 +- nimbus/sync/beacon/worker.nim | 4 -- nimbus/sync/beacon/worker/blocks_staged.nim | 5 +-- nimbus/sync/beacon/worker/db.nim | 4 -- nimbus/sync/beacon/worker/headers_staged.nim | 31 +------------- nimbus/sync/beacon/worker/start_stop.nim | 28 +++---------- nimbus/sync/beacon/worker/update.nim | 44 +++++--------------- nimbus/sync/beacon/worker_config.nim | 4 -- nimbus/sync/beacon/worker_desc.nim | 10 +---- 11 files changed, 26 insertions(+), 116 deletions(-) diff --git a/nimbus/beacon/api_handler/api_forkchoice.nim b/nimbus/beacon/api_handler/api_forkchoice.nim index e887e25371..48ef5da587 100644 --- a/nimbus/beacon/api_handler/api_forkchoice.nim +++ b/nimbus/beacon/api_handler/api_forkchoice.nim @@ -114,7 +114,7 @@ proc forkchoiceUpdated*(ben: BeaconEngineRef, # Update sync header (if any) com.syncReqNewHead(header) - com.reqBeaconSyncTargetCB(header, update.finalizedBlockHash) + com.reqBeaconSyncTargetCB(header) return simpleFCU(PayloadExecutionStatus.syncing) diff --git a/nimbus/common/common.nim b/nimbus/common/common.nim index ea2958fcea..e6ea143eb5 100644 --- a/nimbus/common/common.nim +++ b/nimbus/common/common.nim @@ -43,7 +43,7 @@ type SyncReqNewHeadCB* = proc(header: Header) {.gcsafe, raises: [].} ## Update head for syncing - ReqBeaconSyncTargetCB* = proc(header: Header; finHash: Hash32) {.gcsafe, raises: [].} + ReqBeaconSyncTargetCB* = proc(header: Header) {.gcsafe, raises: [].} ## Ditto (for beacon sync) NotifyBadBlockCB* = proc(invalid, origin: Header) {.gcsafe, raises: [].} @@ -344,10 +344,10 @@ proc syncReqNewHead*(com: CommonRef; header: Header) if not com.syncReqNewHead.isNil: com.syncReqNewHead(header) -proc reqBeaconSyncTargetCB*(com: CommonRef; header: Header; finHash: Hash32) = +proc reqBeaconSyncTargetCB*(com: CommonRef; header: Header) = ## Used by RPC updater if not com.reqBeaconSyncTargetCB.isNil: - com.reqBeaconSyncTargetCB(header, finHash) + com.reqBeaconSyncTargetCB(header) proc notifyBadBlock*(com: CommonRef; invalid, origin: Header) {.gcsafe, raises: [].} = diff --git a/nimbus/sync/beacon/README.md b/nimbus/sync/beacon/README.md index 6dbcab5eb9..5c80307014 100644 --- a/nimbus/sync/beacon/README.md +++ b/nimbus/sync/beacon/README.md @@ -219,7 +219,7 @@ Running the sync process for *MainNet* -------------------------------------- For syncing, a beacon node is needed that regularly informs via *RPC* of a -recently finalised block header. +recent target block header. The beacon node program used here is the *nimbus_beacon_node* binary from the *nimbus-eth2* project (any other, e.g.the *light client* will do.) @@ -230,7 +230,7 @@ The beacon node program used here is the *nimbus_beacon_node* binary from the --jwt-secret=/tmp/jwtsecret where *http://127.0.0.1:8551* is the URL of the sync process that receives the -finalised block header (here on the same physical machine) and `/tmp/jwtsecret` +target block headers (here on the same physical machine) and `/tmp/jwtsecret` is the shared secret file needed for mutual communication authentication. It will take a while for *nimbus_beacon_node* to catch up (see the diff --git a/nimbus/sync/beacon/worker.nim b/nimbus/sync/beacon/worker.nim index eb327b33f9..e3b3515ba9 100644 --- a/nimbus/sync/beacon/worker.nim +++ b/nimbus/sync/beacon/worker.nim @@ -170,10 +170,6 @@ proc runPeer*( buddy.only.multiRunIdle = Moment.now() - buddy.only.stoppedMultiRun buddy.only.nMultiLoop.inc # statistics/debugging - # Update consensus header target when needed. It comes with a finalised - # header hash where we need to complete the block number. - await buddy.headerStagedUpdateTarget info - if not await buddy.napUnlessSomethingToFetch(): # # Layout of a triple of linked header chains (see `README.md`) diff --git a/nimbus/sync/beacon/worker/blocks_staged.nim b/nimbus/sync/beacon/worker/blocks_staged.nim index d772109fe9..dc234141f9 100644 --- a/nimbus/sync/beacon/worker/blocks_staged.nim +++ b/nimbus/sync/beacon/worker/blocks_staged.nim @@ -291,8 +291,7 @@ proc blocksStagedImport*( iv = BnRange.new(qItem.key, qItem.key + nBlocks.uint64 - 1) info "Importing blocks", iv, nBlocks, - base=ctx.chain.baseNumber.bnStr, head=ctx.chain.latestNumber.bnStr, - target=ctx.layout.final.bnStr + base=ctx.chain.baseNumber.bnStr, head=ctx.chain.latestNumber.bnStr var maxImport = iv.maxPt block importLoop: @@ -343,7 +342,7 @@ proc blocksStagedImport*( ctx.updateMetrics() info "Import done", iv, nBlocks, base=ctx.chain.baseNumber.bnStr, - head=ctx.chain.latestNumber.bnStr, target=ctx.layout.final.bnStr + head=ctx.chain.latestNumber.bnStr return true # ------------------------------------------------------------------------------ diff --git a/nimbus/sync/beacon/worker/db.nim b/nimbus/sync/beacon/worker/db.nim index c165b1421e..9a5cb4c0ae 100644 --- a/nimbus/sync/beacon/worker/db.nim +++ b/nimbus/sync/beacon/worker/db.nim @@ -92,10 +92,6 @@ proc dbLoadSyncStateLayout*(ctx: BeaconCtxRef; info: static[string]): bool = # If there was a manual import after a previous sync, then saved state # might be outdated. if rc.isOk and - # The base number is the least record of the FCU chains/tree. So the - # finalised entry must not be smaller. - ctx.chain.baseNumber() <= rc.value.final and - # If the latest FCU number is not larger than the head, there is nothing # to do (might also happen after a manual import.) latest < rc.value.head and diff --git a/nimbus/sync/beacon/worker/headers_staged.nim b/nimbus/sync/beacon/worker/headers_staged.nim index f5518fed86..60ac957294 100644 --- a/nimbus/sync/beacon/worker/headers_staged.nim +++ b/nimbus/sync/beacon/worker/headers_staged.nim @@ -19,7 +19,7 @@ import ../worker_desc, ./update/metrics, ./headers_staged/[headers, linked_hchain], - "."/[headers_unproc, update] + ./headers_unproc # ------------------------------------------------------------------------------ # Private functions @@ -53,35 +53,6 @@ proc fetchAndCheck( # Public functions # ------------------------------------------------------------------------------ -proc headerStagedUpdateTarget*( - buddy: BeaconBuddyRef; - info: static[string]; - ) {.async: (raises: []).} = - ## Fetch finalised beacon header if there is an update available - let - ctx = buddy.ctx - peer = buddy.peer - if ctx.layout.lastState == idleSyncState and - ctx.target.final == 0 and - ctx.target.finalHash != zeroHash32 and - not ctx.target.locked: - const iv = BnRange.new(1u,1u) # dummy interval - - ctx.target.locked = true - let rc = await buddy.headersFetchReversed(iv, ctx.target.finalHash, info) - ctx.target.locked = false - - if rc.isOk: - let hash = rlp.encode(rc.value[0]).keccak256 - if hash != ctx.target.finalHash: - # Oops - buddy.ctrl.zombie = true - debug info & ": finalised header hash mismatch", peer, hash, - expected=ctx.target.finalHash - else: - ctx.updateFinalBlockHeader(rc.value[0], ctx.target.finalHash, info) - - proc headersStagedCollect*( buddy: BeaconBuddyRef; info: static[string]; diff --git a/nimbus/sync/beacon/worker/start_stop.nim b/nimbus/sync/beacon/worker/start_stop.nim index 43fd9b8a1c..eef32c91ae 100644 --- a/nimbus/sync/beacon/worker/start_stop.nim +++ b/nimbus/sync/beacon/worker/start_stop.nim @@ -38,7 +38,7 @@ when enableTicker: head: ctx.layout.head, headOk: ctx.layout.lastState != idleSyncState, target: ctx.target.consHead.number, - targetOk: ctx.target.final != 0, + targetOk: ctx.target.changed, nHdrStaged: ctx.headersStagedQueueLen(), hdrStagedTop: ctx.headersStagedQueueTopKey(), @@ -62,31 +62,13 @@ proc updateBeaconHeaderCB( ): ReqBeaconSyncTargetCB = ## Update beacon header. This function is intended as a call back function ## for the RPC module. - return proc(h: Header; f: Hash32) {.gcsafe, raises: [].} = - - # Check whether there is an update running (otherwise take next upate) - if not ctx.target.locked and # ignore if currently updating - ctx.target.final == 0 and # ignore if complete already - f != zeroHash32 and # finalised hash is set + return proc(h: Header) {.gcsafe, raises: [].} = + if ctx.chain.baseNumber() < h.number and # sanity check ctx.layout.head < h.number and # update is advancing ctx.target.consHead.number < h.number: # .. ditto - ctx.target.consHead = h - ctx.target.finalHash = f - ctx.target.changed = true - - # Check whether `FC` knows about the finalised block already. - # - # On a full node, all blocks before the current state are stored on the - # database which is also accessed by `FC`. So one can already decude here - # whether `FC` id capable of handling that finalised block (the number of - # must be at least the `base` from `FC`.) - # - # Otherwise the block header will need to be fetched from a peer when - # available and checked there (see `headerStagedUpdateTarget()`.) - # - let finHdr = ctx.chain.headerByHash(f).valueOr: return - ctx.updateFinalBlockHeader(finHdr, f, info) + ctx.target.changed = true # enable this dataset + ctx.updateFromHibernating info # wake up if sleeping # ------------------------------------------------------------------------------ # Public functions diff --git a/nimbus/sync/beacon/worker/update.nim b/nimbus/sync/beacon/worker/update.nim index 065da9148b..e55390b413 100644 --- a/nimbus/sync/beacon/worker/update.nim +++ b/nimbus/sync/beacon/worker/update.nim @@ -156,8 +156,6 @@ proc setupCollectingHeaders(ctx: BeaconCtxRef; info: static[string]) = ctx.sst.layout = SyncStateLayout( coupler: c, dangling: h, - final: ctx.target.final, - finalHash: ctx.target.finalHash, head: h, lastState: collectingHeaders) # state transition @@ -282,17 +280,16 @@ proc updateSyncState*(ctx: BeaconCtxRef; info: static[string]) = # Check whether the system has been idle and a new header download # session can be set up if prevState == idleSyncState and - ctx.target.changed and # and there is a new target from CL - ctx.target.final != 0: # .. ditto + ctx.target.changed: # and there is a new target from CL ctx.setupCollectingHeaders info # set up new header sync return # Notreached info "Sync state changed", prevState, thisState, head=ctx.chain.latestNumber.bnStr, - oldBase=(if ctx.layout.coupler == ctx.layout.dangling: "downloaded" + coupler=(if ctx.layout.coupler == ctx.layout.dangling: "dangling" else: ctx.layout.coupler.bnStr), - downloaded=(if ctx.layout.dangling == ctx.layout.head: "target" + dangling=(if ctx.layout.dangling == ctx.layout.head: "target" else: ctx.layout.dangling.bnStr), target=ctx.layout.head.bnStr @@ -313,33 +310,14 @@ proc updateSyncState*(ctx: BeaconCtxRef; info: static[string]) = ctx.startHibernating info -proc updateFinalBlockHeader*( - ctx: BeaconCtxRef; - finHdr: Header; - finHash: Hash32; - info: static[string]; - ) = - ## Update the finalised header cache. If the finalised header is acceptable, - ## the syncer will be activated from hibernation if necessary. - ## - let - b = ctx.chain.baseNumber() - f = finHdr.number - if f < b: - trace info & ": finalised block # too low", - B=b.bnStr, finalised=f.bnStr, delta=(b - f) - - ctx.target.reset - - else: - ctx.target.final = f - ctx.target.finalHash = finHash - - # Activate running (unless done yet) - if ctx.hibernate: - ctx.hibernate = false - info "Activating syncer", base=b.bnStr, head=ctx.chain.latestNumber.bnStr, - finalised=f.bnStr, target=ctx.target.consHead.bnStr +proc updateFromHibernating*(ctx: BeaconCtxRef; info: static[string]) = + ## Activate syncer if hibernating. + if ctx.hibernate: + ctx.hibernate = false # activates syncer + debug info & ": activating syncer", T=ctx.target.consHead.bnStr + + # Re-calculate sync state + ctx.updateSyncState info # Update, so it can be followed nicely ctx.updateMetrics() diff --git a/nimbus/sync/beacon/worker_config.nim b/nimbus/sync/beacon/worker_config.nim index ba75723004..9d98b160e7 100644 --- a/nimbus/sync/beacon/worker_config.nim +++ b/nimbus/sync/beacon/worker_config.nim @@ -128,10 +128,6 @@ const ## entry block number is too high and so leaves a gap to the ledger state ## block number.) - finaliserChainLengthMax* = 32 - ## When importing with `importBlock()`, finalise after at most this many - ## invocations of `importBlock()`. - # ---------------------- static: diff --git a/nimbus/sync/beacon/worker_desc.nim b/nimbus/sync/beacon/worker_desc.nim index ff191ec014..be8ee78698 100644 --- a/nimbus/sync/beacon/worker_desc.nim +++ b/nimbus/sync/beacon/worker_desc.nim @@ -72,11 +72,8 @@ type SyncStateTarget* = object ## Beacon state to be implicitely updated by RPC method - locked*: bool ## Don't update while fetching header changed*: bool ## Tell that something has changed consHead*: Header ## Consensus head - final*: BlockNumber ## Finalised block number - finalHash*: Hash32 ## Finalised hash SyncStateLayout* = object ## Layout of a linked header chains defined by the triple `(C,D,H)` as @@ -95,14 +92,9 @@ type ## coupler*: BlockNumber ## Bottom end `C` of full chain `(C,H]` dangling*: BlockNumber ## Left end `D` of linked chain `[D,H]` - head*: BlockNumber ## `H`, block num of some finalised block + head*: BlockNumber ## `H`, block number of some target block lastState*: SyncLayoutState ## Last known layout state - # Legacy entries, will be removed some time. This is currently needed - # for importing blocks into `FC` the support of which will be deprecated. - final*: BlockNumber ## Finalised block number `F` - finalHash*: Hash32 ## Hash of `F` - SyncState* = object ## Sync state for header and block chains target*: SyncStateTarget ## Consensus head, see `T` in `README.md`