今日运势评分

-3

本月运势

丁亥月

震荡偏多

丁破格,未害子
丁不剃头头必生疮
未不服药毒气入肠

订盟,纳采,会亲友,祭祀,祈福,修造,动土,安机械,破土,安葬

嫁娶,移徙,出火,开市,入宅

月相

日冲

Powered by RitMEX

ONDO0.48 -4.52%

TRUMP5.87 -2.50%

SUI1.63 -2.29%

TON1.58 -2.26%

TRX0.29 1.68%

DOGE0.14 -3.30%

XRP2.07 -3.34%

SOL136.94 -4.11%

BNB893.69 -1.63%

ETH3131.94 -1.55%

BTC91278.99 -1.85%

ETH Gas0.36 Gwei

恐惧
26

详解 OP Stack Rollup 流程及对应代码

OP Stack 是标准化、共享和开源的开发堆栈,为 Optimism 提供支持,由 Optimism Collective 维护。

撰文:Rayer

Optimism Bedrock 是 OP Stack 的当前版本。Bedrock 版本提供了用于启动生产质量的 Optimistic Rollup 区块链的工具。此时,OP Stack 不同层的 API 仍然与 Stack 的 Rollup 配置紧密耦合。

Op-stack 主要的 rollup 由两个服务来承担。

  • op-batcher:负责将每隔一段时间读取 sequencer 上的交易内容,rollup 到链上 DA

  • op-proposer:负责将交易状态 rollup 到合约。

Rollup 架构

op-batcher

op-batcher 执行流程图

loadBlocksInfoState 执行逻辑

loadBlocksInfoState 负责读取,从前一次读取的块开始的所有块,即还未读取的块。

其整体流程如下

代码如下:

loadBlocksIntoState 完成了以下动作

1、获取 sequencer 中的同步状态

2、153 行,调用calculateL2BlockRangeToStore函数

  • calculateL2BlockRangeToStore 获取并判断需要提交的最新 L2 的 start 和 end 块号,起始的区块为 L2 当前安全的最高块,结束区块为 L2 当前最高的不安全的区块。

3、164 行,拿到提交的开始块和结束区块之后,从起始区块开始获取区块信息,调用loadBlockIntoState 函数获取区块

  • loadBlockIntoState 检查区块信息以及 geth 信息,无误后,在 200 行,调用 AddL2Block函数将区块加到 channelManager 的 blocks []*types.Block 中。

4、165 行至 168 行,校验区块是否需要重新提交,若需要,将 l.lastStoredBlock 置成 eth.BlockID{};173 行,否则就将 l.lastStoredBlock 置成 eth.ToBlockID(block);latestBlock 置成 block;

5、177 行L2BlockToBlockRef从 L2 块引用源中提取基本的 L2BlockRef 信息,根据区块号判断必要时回退到创世信息

publishStateToL1 执行逻辑

publishStateToL1 将队列中的所有交易提交到 L1,直到队列中没有交易或者出现错误为止。

代码如下:

1、publishStateToL1 会循环将队列里的交易发送到 Layer1 网络。

2、377 行调用publishTxToL1

publishTxToL1 是提交单个交易到 L1 的逻辑,publishTxToL1 方法获取要提交的数据数据构建交易发送到 Layer1 网络,并将发送出去的交易扔到 receiptCh chan TxReceipt[T] channel 里面。

  1. 429 行l1Tip:获取当前 L1 提示作为 L1BlockRef。假定传递的上下文是生命周期上下文,因此它在内部使用网络超时进行包装。

  2. 434 行recordL1Tip:将上一个 L1BlockRef 更换成 l1Tip 获取到的最新的 L1BlockRef

  3. 437 行TxData:收集需要 rollup 的交易数据;TxData 返回应提交给 L1 的下一个 tx 数据。目前,每个事务仅使用一帧。如果待处理的通道已满,则仅返回该通道的剩余帧,直到成功完全发送到 L1。如果没有挂起的帧,它将返回 io.EOF。

  4. 447 行sendTransaction将交易发送到一层,并把交易发送状态更新到 receiptCh chan TxReceipt[T] channel 里面;sendTransaction 使用给定的「数据」创建交易并将其提交到批处理收件箱地址。它目前使用底层的「txmgr」来处理交易发送和价格管理。这是一种阻塞方法。不应同时调用它。

handleReceipt

handleReceipt 获取从 channel 处理交易的状态,并将成功处理的交易从 channel 里面移除。

代码如下:

op-proposer

执行流程图

详细执行流程

FetchNextOutputInfo

FetchNextOutputInfo: 获取 L2 上的区块的 output,方便后续组装提交。返回的 output 结构如下:

type OutputResponse struct {Version               Bytes32     json:"version"OutputRoot            Bytes32     json:"outputRoot"BlockRef              L2BlockRef  json:"blockRef"WithdrawalStorageRoot common.Hash json:"withdrawalStorageRoot"StateRoot             common.Hash json:"stateRoot"Status                *SyncStatus json:"syncStatus"}

 

代码如下:

  1. 224 行,NextBlockNumber:获取下一批次需要提交的区块区间,区间计算为 latestBlockNumber() + SUBMISSION_INTERVAL SUBMISSION_INTERVAL 的值可以在部署 L2OutputOracle 合约的时候指定。

  2. 230 行,调用FetchCurrentBlockNumber,获得当前区块的区块号

  3. 236 行至 241 行, 上面检查完 nextCheckpointBlock 符合规则之后,调用FetchOutput去 L2 上获取需要提交的 stateRoot

FetchCurrentBlockNumber 代码如下:

1、254 行,SyncStatus:获取 L2 块的 SafeL2 和 FinalizedL2 的状态和块信息,

FetchOutput 代码如下:

2、279 行OutputAtBlock: 根据块高获取 output, 里面包含 stateRoot,这里最终是调用 eth_getProof 去计算并获取 stateRoot,代码调用流程可以参考上图。提示: 这里并不是一个块提交一次 stateRoot, 而是根据 SUBMISSION_INTERVAL 配置的值来计算一批块的 stateRoot,最终将 stateRoot 提交到 L2OutputOracle 合约

send Transaction

  • sendTransaction:使用 output 构建 stateRoot 提交交易,将交易提交到一层链, 下面是交易打包的数据细节

return abi.Pack(    "proposeL2Output",    output.OutputRoot,    new(big.Int).SetUint64(output.BlockRef.Number),    output.Status.CurrentL1.Hash,    new(big.Int).SetUint64(output.Status.CurrentL1.Number))

代码如下:

欢迎加入深潮TechFlow官方社群

Telegram订阅群:https://t.me/TechFlowDaily
Twitter官方账号:https://x.com/TechFlowPost
Twitter英文账号:https://x.com/BlockFlow_News
作者登链社区@UpchainDAO
相关文章
2025.12.05 - 3 小时前
“五虎争霸赛”圆满收官|JST、SUN、NFT夺魁!SUN.io接棒生态新动能
JST、SUN、NFT三大资产领跑,引爆交易与社区活跃度,更推动大量资金涌入生态,最终由一站式平台SUN.io承接并转化为长期增长动能。
2025.12.05 - 8 小时前
加密「低潮期」的疗愈:如何终结模因币的价值漏斗?
责任不在当前提供者,而在需要进步的消费者,市场自会适应。
2025.12.05 - 9 小时前
以太坊孤岛终结:EIL 如何将破碎的 L2 重构为一台「超级计算机」?
EIL 是以太坊账户抽象团队给出的最新答案,也是互操作路线图「加速」阶段的核心。
2025.12.04 - 昨天
交易额破 4.1 亿,孙悟空“交易挖矿”首期战报出炉,手续费超额返还引爆市场
目前,孙悟空第一期交易挖矿活动已进入下半场。活动将于2025年12月6日20:00(UTC+8) 正式收官。
2025.12.04 - 昨天
Space 回顾|通胀回升 vs 市场押注降息,宏观波动下如何保持谨慎的加密资产配置?
面对宏观波动,波场TRON生态通过稳定币结算、生息资产及创新业务,提供了一个“攻守兼备”的资产配置范例。
2025.12.03 - 前天
不止于交易:孙悟空如何用“真金白银”为 SUN 铸造价值闭环
在流量与叙事的喧嚣之后,只有那些能将增长红利清晰、公平地回馈给用户的项目,才能穿越周期,构建真正坚固的护城河。
2025.12.03 - 前天
x402 协议:机器经济时代的支付革命与合规挑战
x402 协议的诞生,恰似 17 世纪汇票挑战金银本位——新经济形态总是先于规则破茧。
2025.12.02 - 3 天前
Aethir 公布未来 12 个月战略路线图,全面加速全球 AI 企业算力基础设施建设
Aethir 核心愿景始终是推动全球用户实现通用化、去中心化的云计算能力。
2025.12.02 - 3 天前
Kalshi 联手 Solana:美国第一合规预测市场开始收割加密人?
Kalshi 需要的不是「再建一条链」,而是「插上现成的翅膀」。Solana 恰好就是那双翅膀。
2025.12.02 - 3 天前
从梭哈到永续,微策略 14.4 亿美元现金储备解读
当最大的BTC持有者不购买甚至还要卖出BTC的时候,会为市场带来怎样的影响?