Cointime

扫码下载App
iOS & Android

探讨 ZK Rollup 中「证明溢出」问题:有哪些解决方案?

项目方

要解决「证明溢出」问题需要解决以下问题:如何防止创建超出电路容量的批次?

撰文: Andy Arditi

在 Scroll,我们正在开放构建 zkEVM,并希望将我们正在构建的协议的所有方面保持公开透明。

这篇文章中描述了我们称之为「证明溢出」的问题 — 一个由于 ZK rollups 中执行和证明生成分离而引起的问题。

背景

Scroll 的 rollup 流程大致可以理解为:

  • 用户向 Scroll 的内存池提交交易。
  • 排序器 (sequencer) 节点将一些交易打包到一个区块中。
  • 批处理程序 (bather) 将一些区块打包成一个批次 (batch)。
  • 批次的数据(包括其所有交易数据)被发布或「提交」到以太坊 L1
  • 证明者获取批次并生成证明。
  • 该证明可以证明该批次中的所有交易均已正确执行。
  • 该证明提交给以太坊 L1 进行验证。相应的批次被认为是「最终确认的」。

我们在 Alpha 测试网中遇到的一个问题是无法证明某些批次,原因是它们「太大」而无法放入我们的 zkEVM 电路中。

人们可以认为 zkEVM 电路由许多子电路组成,比如 n 个子电路,它们通过查找表互连。每个子电路用于约束特定的操作——例如,Keccak 电路计算 Keccak 哈希,求幂电路计算求幂。我们的 zkEVM 电路设计中当前限制是每个子电路必须具有相同的行数,比如 m 行。

根据每个子电路中消耗的行数,每个所传入的交易都具有唯一的配置文件。例如,可能有一个交易需要许多 Keccak 操作,因此在 Keccak 电路中占用许多行,而在求幂电路中不占用任何行。相反,可能有一个交易在 Keccak 电路中占用很少的行,而在求幂电路中占用很多行。

由于批次由区块组成,而区块由交易组成,因此批次的行消耗配置文件由组成它的交易决定。如果一个批次的行消耗超过最大行数 m,则该批次将无法证明(即证明「溢出」)。当一个批次无法证明时,它无法在 L1 上最终确认,任何后续的批次也无法证明(取决于无法证明批次的结果状态)。

值得注意的是,即使只包含单个交易的批次也可能会溢出电路。

要解决「证明溢出」问题需要解决以下问题:如何防止创建超出电路容量的批次?

长期解决方案

问题源于我们电路架构的局限性:所有子电路都必须有一些预先确定的、固定数量的行。我们正在研究重新设计我们的架构,以便可以独立地动态调整子电路的大小——每个子电路的大小都可以根据批次证明的要求放大或缩小。例如,如果一个批次在 Keccak 电路中需要 2^20 行,但在求幂电路中只需要 2^14 行,则子电路可以独立缩放。

这种类型的动态设计带来了挑战,我们正在努力解决这些问题。然而,与此同时,我们需要解决固定尺寸电路的问题。

当前解决方案

1. 根据最坏情况下的操作码设置区块 Gas 限制 ❌

这里的想法是根据最坏情况下(就电路行消耗而言最昂贵)的操作码来设置区块的 Gas 限制。换句话说,设置区块 Gas 限制,即使它被最昂贵的操作码填满,该区块仍然可以适配我们的电路。这保证了任何区块都无法填满电路。

  • 优点:简单
  • 缺点
  • 非常低效
  • 分析表明,最昂贵的操作码 (SHA) 的证明行与 EVM Gas 之间的比率约为 11 倍。
  • 每个额外的 Keccak 字节占用约 2.2 行,同时消耗约 6/32 EVM gas。对于 m = 2^20(大约 100 万行),我们可以容纳大约 2^20 / 2.2 个 Keccak 字节。这对应于 (2^20 / 2.2) * (6/32) ~= 89,000 gas 的最大区块限制。太小!!

2. Gas 重新定价 ⚠️

我们可以修改操作码到 Gas 的映射表来反映证明成本,而不是执行成本。这将涉及从每个操作码与它在所有子电路中占用的最大行数的静态映射,然后修改我们的 Geth 分支(「L2Geth」)以使用这个新的 Gas 定价。

  • 优点:
  • 证明溢出问题在执行层被处理为「Out of Gas」错误
  • 缺点
  • 可能会破坏依赖于正常 EVM Gas 定价的合约。
  • 很难以编程方式将操作码映射到行消耗。
  • 这个映射应该是可编程的,因为 zkEVM 的电路库会随着时间的推移而改变,也因为手工分析容易出错,这里稍有错误就会导致溢出漏洞
  • 需要保持 L2Geth Gas 定价和 zkEVM 电路库之间的同步 - 不同步将导致漏洞

3. 引入额外的「Proof Gas」计量

除了正常的 EVM Gas 之外,我们还可以有一个单独的概念 「Proof Gas」。Proof Gas 将用于量化交易在我们的电路中消耗的空间。请注意,这种「Proof Gas」应该是多维的——因为不同的操作码在不同的电路中占据不同的行。

一旦引入「Proof Gas」计量的概念,就会出现在哪个级别约束它的问题。

3a.在执行层约束 Proof Gas

此解决方案与解决方案 2 类似,不同之处在于它保留了 EVM Gas 和 Proof Gas 的概念。这将再次涉及将每个操作码静态映射到它在每个电路中占用的行数,然后修改 L2Geth 以添加这种 Proof Gas 的概念。如果特定交易超过了 Proof Gas 限制,则交易将撤销并出现一些自定义的「out of proof gas」的错误。这将确保没有区块可以超过行约束,因为执行层将在此之前停止交易。

  • 优点:
  • 证明溢出问题在执行层被处理为「out of proof gas」错误
  • 缺点
  • 难以生成从操作码到行消耗的静态映射
  • 需要保持 L2Geth 和 zkEVM 电路库之间的同步
  • 需要对 L2Geth 和 zkEVM 电路库中的逻辑进行重大更改,以支持额外的 Proof Gas 概念

3b.在执行层之外约束 Proof Gas

我们可以从 zkEVM 电路库中公开 API 来报告给定执行踪迹所需的行数,而不是生成操作码到电路行的静态映射。L2Geth 可以生成区块的执行踪迹,然后查询电路行消耗 —— 如果超过最大行数,则不会创建区块。

  • 优点:
  • 无需以编程方式将操作码映射到行消耗所需的复杂性。
  • 缺点:
  • 当必须构造一个区块时,L2Geth 会增加一些计算开销,因为它需要进行额外的计算来估计电路行消耗。
  • 使强制包含(Forced Inclusion)变得复杂。
  • 强制包含是一种机制,用户可以直接通过 L1 提交 L2 交易。这些交易被「强制」包含在 L2 链中,作为一种抗审查机制。
  • 我们无法将交易映射到它在 L1 上消耗的电路行数,因此无法判断它是否可证明

结语

似乎解决方案 3b 是最简单且风险最小,也是可行的解决方案。

伴随这种方案的主要挑战是如何处理强制交易,因为可能存在太大而无法放入电路中的强制交易。这里的一个想法是使用解决方案 1 中的想法来限制强制交易的 Gas 限制,这样即使在最坏的情况下,强制交易也不会溢出电路。

从长远来看,我们的目标是开发一个更灵活的证明系统,支持动态大小的子电路,从而完全避免这个问题。

评论

所有评论

推荐阅读

  • 美国有条件放松对伊朗油品的制裁 为期30天

    Cointime 报道,3月21日,据美国财政部消息,美国于当地时间3月20日批准了为期30天的授权,有条件放松对伊朗油品的制裁,对于截至3月20日已经装船的伊朗原油和石油产品,允许其交付和销售。美国财长贝森特表示,财政部正在发布一项“范围狭窄、期限较短的授权”,允许出售目前滞留在海上的伊朗石油。通过暂时释放现有的石油供应,美国将迅速向全球市场提供约1.4亿桶石油。临时、短期授权严格限于已在运输途中的石油。(央视新闻)

  • 金色晨讯 | 3月21日隔夜重要动态一览

    21:00-7:00关键词:加息、Strategy、Clarity Act、灰度 1.交易员预计到十月美联储加息的概率为50% 2.a16z联创:OpenClaw和Pi Coding Agent结合是有史以来十大软件突破之一 3.Strategy CEO:若摩根士丹利按资管规模2%配置BTC或带来1600亿美元潜在买盘 4.美股三大指数集体收跌 5.灰度向美SEC提交Grayscale HYPE ETF的初始S-1文件 6.特朗普称正考虑逐步降级对伊朗的军事行动 7.美参议员就稳定币收益达成原则性妥协,《Clarity Act》推进取得进展

  • 特朗普称正考虑逐步降级对伊朗的军事行动

    Cointime 报道,3月21日,美国总统唐纳德·特朗普当地时间3月20日在其社交媒体“真实社交”发文表示,随着他们考虑逐步降级在中东针对伊朗政权所开展的各项重大军事行动,他们已非常接近实现既定目标:彻底削弱伊朗的导弹能力、发射装置及所有相关设施。摧毁伊朗的国防工业基础。消灭伊朗海空军力量,包括防空武器系统。绝不允许伊朗哪怕是接近拥有核能力;同时,美国必须始终保持一种态势,以便一旦出现此类情况,能够迅速且强有力地予以反击。以最高级别的力度,保护美国在中东的盟友,包括以色列、沙特阿拉伯、卡塔尔、阿拉伯联合酋长国、巴林、科威特及其他国家。 特朗普称,霍尔木兹海峡的守卫与巡航工作,应在必要时由其他使用该海峡的国家来承担,美国将不再承担此责任。若受邀协助,美国愿为这些国家在霍尔木兹海峡的行动提供支持,但一旦伊朗的威胁被彻底消除,此类协助便将不再必要。尤为重要的是,对于这些国家而言,这将是一次轻而易举的军事行动。 (央视新闻)

  • 灰度向美SEC提交Grayscale HYPE ETF的初始S-1文件

    Cointime 报道,灰度向美国证券交易委员会(SEC)提交了 Grayscale HYPE ETF(代码: GHYP)的初始 S-1 文件。并表示,“注册声明尚未生效。在注册声明生效之前,不得出售股份,也不得接受购买要约。

  • 分析:比特币跌破6.6万美元或引发10%-20%深度下跌

    3 月 21 日,持牌市场技术分析师(CMT)Aksel Kibar 表示,比特币潜在上升楔形形态的下边界支撑位位于 66,000 美元,若跌破可能引发熊市反转。上升楔形作为经典技术形态,通常在上涨趋势末期出现,预示价格动能衰竭,历史数据显示类似下跌突破确认后平均回调 10-20%。

  • 白宫称特朗普没有向伊朗派兵的计划

    3 月 20 日,一位白宫官员表示,尽管有新的部队调动以及可能封锁哈尔克岛的报道,特朗普「没有」向伊朗部署军队的计划。这位官员补充说,美军「随时可以夺取哈尔克岛」,但目前仍保留多种选择,不会透露具体战略。

  • 美国向伊朗增兵引发市场恐慌,金银、美股快速下跌,比特币跌破7万美元大关

    3 月 20 日,据 Bitget 行情信息,报道称美国将向中东增派兵力后,现货黄金向下触及 4550 美元/盎司,日内跌 2.19%。现货白银日内重挫 6.00%,现报 68.45 美元/盎司。美元指数 DXY 日内涨超 0.5%,报 99.76。此外,标普 500 指数跌幅扩大至 1%、纳斯达克指数现跌 1.36%。而短期利率期货价格显示,市场预计美联储很可能在 12 月加息。另据 HTX 行情信息,比特币跌破 7 万美元,现报 69761.56 美元。此前消息,美国正在向中东派遣三艘军舰,并向中东增派数千名海军陆战队员。

  • 伊朗最高领袖就伊朗新年发表书面贺词

    3 月 20 日,伊朗最高领袖穆杰塔巴·哈梅内伊刚刚就即将到来的伊朗传统节日诺鲁孜节(3 月 21 日),也就是伊朗传统新年发表书面贺词。穆杰塔巴表示,过去一年伊朗经历多轮「军事与安全冲突」,造成包括军方指挥官和民众在内的人员伤亡。他指责以色列在美国支持下对伊朗实施袭击,并称相关行动未能达到其预期目标。在谈及国内局势时,穆杰塔巴表示,外部势力试图通过经济压力和舆论手段影响伊朗社会稳定,但伊朗民众的动员能力和社会凝聚力有效挫败了相关企图。经济方面,穆杰塔巴强调,应通过发展「抵抗经济」、改善民生和基础设施建设来增强国家韧性。在外交层面,他表示伊朗将继续重视与邻国关系,呼吁包括巴基斯坦、阿富汗等在内的地区国家加强合作与团结。(CCTV 国际时讯)

  • 美CFTC发布加密资产与区块链业务FAQ,强化监管规则一致性

    3 月 20 日,美国商品期货交易委员会(CFTC)主席 Mike Selig 在 X 平台发文表示,该监管机构已发布关于加密资产及区块链相关业务的常见问题解答(FAQ),进一步明确注册机构及交易实体的合规指引。据悉,其中内容涉及围绕代币化抵押品及数字资产作为保证金等问题,补充解释了此前发布的两份员工函(代币化托管指引与数字资产保证金无行动豁免指引),为市场参与者提供更清晰的操作框架。Mike Selig 补充称,随着「Project Crypto」成为联合推进项目,与美国证券交易委员会(SEC)保持一致,也是推动加密监管规则清晰化与统一化的重要一步。

  • 特朗普:伊朗已经没有领导人可以对话

    3 月 20 日,特朗普表示,伊朗已经没有领导人可以对话了,也没人想再当伊朗领导人了。