火星链 火星链
Ctrl+D收藏火星链

Proof:“证明溢出”问题

作者:

时间:1900/1/1 0:00:00

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

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

背景

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

1.用户向Scroll的内存池提交交易。

2.排序器(sequencer)节点将一些交易打包到一个区块中。

3.批处理程序(bather)将一些区块打包成一个批次(batch)。

批次的数据被发布或“提交”到以太坊L14.证明者获取批次并生成证明。

该证明可以证明该批次中的所有交易均已正确执行。该证明提交给以太坊L1进行验证。相应的批次被认为是“最终确认的”。我们在Alpha测试网中遇到的一个问题是无法证明某些批次。愿意是它们“太大”而无法放入我们的zkEVM电路中。

Ether.Fi:OpenSea无故停止质押以太坊NFT交易:金色财经报道,Ether.Fi首席执行官Mike Silagadze发布公开信表示,OpenSea停止了其质押以太坊NFT的交易。 Ether.Fi是一个去中心化和非托管的以太坊质押协议,7月11日推出了ether.fan,这是一个由质押ETH支持的NFT系列,专注于以太坊去中心化。Mike Silagadze在信中表示,新NFT系列似乎已被OpenSea禁用,但没有收到任何通知或警告。

Silagadze表示,OpenSea套用回复模板称,不允许NFT集合开展任何需要注册或许可的金融活动,但没有进行任何具体的解释。[2023/7/19 11:03:25]

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

Top 100 DeFi通证市值为48,491,091,178美元:金色财经报道,据最新数据显示,Top 100 DeFi通证市值为48,491,091,178美元,总锁仓量为56,986,142,934美元。目前市值排名前三的DeFi通证分别是:Lido Staked Ether(13,329,447,825美元)、Dai(4,587,985,424美元)和Uniswap(3,823,615,098美元)。[2023/6/4 11:56:41]

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

IMF副总裁:应采取监管行动以避免加密货币对传统金融带来系统性风险:金色财经报道,国际货币基金组织(IMF)副总裁呼吁在监管方面采取更多行动,以避免加密货币的起伏影响银行和传统金融机构。国际货币基金组织金融监管司副处长杉本信泰和国际货币基金组织副总裁李波认为,鉴于传统金融与加密货币之间的联系日益紧密,加密货币的波动性可能会给现有金融体系带来系统性风险。

IMF 博客文章指出,发达经济体也容易受到加密货币带来的金融稳定风险的影响,因为机构投资者在之前 的低利率环境中被更高的回报率所吸引,增加了稳定币的持有量。[2023/1/22 11:25:38]

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

Coinbase:已经解决了coinbase.com和移动应用程序性能下降的问题:金色财经报道,Coinbase表示,已经解决了coinbase.com和移动应用程序性能下降的问题。[2023/1/14 11:11:37]

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

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

长期解决方案

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

安全公司:NFT项目@primordials_ Discord服务器遭到攻击:金色财经报道,据CertiK监测,NFT项目@primordials_ Discord服务器遭到攻击。请社区用户不要点击链接,铸造或批准任何交易。[2022/10/26 16:39:18]

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

当前解决方案

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

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

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

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

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

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

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

3a.在执行层约束ProofGas

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

优点:证明溢出问题在执行层被处理为“outofproofgas”错误缺点难以生成从操作码到行消耗的静态映射需要保持L2Geth和zkEVM电路库之间的同步需要对L2Geth和zkEVM电路库中的逻辑进行重大更改,以支持额外的ProofGas概念3b.在执行层之外约束ProofGas

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

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

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

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

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

标签:GASProofROOETHgas币一分钟暴涨5600倍zkProofWAROOetha币能买不

比特币行情热门资讯
BTC:BTC带盘稳步上行,主流币或将迎来机会

作者|哈希派分析团队声音 | Fundstrat创始人Tom Lee:到2022年,BTC价格将达到25000美元:Fundstrat创始人Tom Lee对比特币价格再一次作出预测.

1900/1/1 0:00:00
WEB:Web3游戏必须走向真正去中心化

0xjereme&Leia|作者导读:为什么许多Web3游戏最终会成为昙花一现的产品,又或者成为旁氏的代言?这是因为它们本质上都是中心化的.

1900/1/1 0:00:00
COIN:这3张图告诉你如何追踪比特币巨鲸的动向

7月10日,据Coinmarketcap显示,比特币上涨突破一年历史中高位达到12955USD,目前比特币市值达到1695亿美元,在过去的三个月内涨幅达到76.48%.

1900/1/1 0:00:00
STE:lCO六年简明史:天才、局和暴富神话

六年前的今天,历史上第一个lCO项目正在募资中。六年时间里,lCO项目的数量从个位数变成了四位数,单个项目的募集金额也从50万美元变为了40亿美元,原本的小众实验变身为大众的狂欢.

1900/1/1 0:00:00
WEB3:从统计数据看 2023 年 Web3 的关键趋势

尽管在TinTinLand社区中,开发者们讨论和交流的Top热词之一是Web3。对于大部分Web2的基数用户来说,Web3依旧是个概念.

1900/1/1 0:00:00
区块链:Web3 的共同梦想

自人类历史的黎明以来,集体故事一直定义着我们的文化,并丰富了我们对世界的理解;讲故事的人一直是塑造这些叙事的推动力.

1900/1/1 0:00:00