eth2.0共识层打包一个新的区块流程:
- 首先会调用执行层引擎 API 的 engine_forkchoiceUpdated 接口,携带 payloadAttributes 参数,执行层返回 payloadId
(api *ConsensusAPI) ForkchoiceUpdatedV2 (api *ConsensusAPI) forkchoiceUpdated miner/(w *worker) buildPayload empty, _, err := w.getSealingBlock(notx::true) go func(){sealblock} return payload
- 其次,共识层调用 engine_getPayload 接口,传入 payloadId,执行层返回 ExecutionPayload 数据。
- 再次,共识层调用 engine_newPalyload 接口,传入 ExecutionPayload 数据,执行层验证交易并返回数据是否有效。
- 最后,共识层调用 engine_forkchoiceUpdated,传入 ForkchoiceState 参数,执行层同步新的区块。