在Scroll,我们正在开放构建zkEVM,并希望将我们正在构建的协议的所有方面保持公开透明。
这篇文章中描述了我们称之为“证明溢出”的问题—?一个由于ZKrollups中执行和证明生成分离而引起的问题。
背景
Scroll的rollup流程大致可以理解为:
1.用户向Scroll的内存池提交交易。
2.排序器(sequencer)节点将一些交易打包到一个区块中。
3.批处理程序(bather)将一些区块打包成一个批次(batch)。
批次的数据被发布或“提交”到以太坊L1
4.证明者获取批次并生成证明。
该证明可以证明该批次中的所有交易均已正确执行。
该证明提交给以太坊L1进行验证。相应的批次被认为是“最终确认的”。
Polymer Labs推出Optimistic ZK IBC Connections,可降低延迟与成本:6月16日消息,专注于IBC协议的基础设施提供商Polymer Labs推出Optimistic ZK IBC Connections。该模型受到OSI模型启发,包含应用层、传输层与状态层。结合Optimistic与零知识证明验证两种技术可以提供具有理想特性的动态延迟:延迟的上限;当中继者受到适当激励时,可能会降低延迟;降低连接维护成本。[2023/6/16 21:42:32]
我们在Alpha测试网中遇到的一个问题是无法证明某些批次。愿意是它们“太大”而无法放入我们的zkEVM电路中。
人们可以认为zkEVM电路由许多子电路组成,比如n个子电路,它们通过查找表互连。每个子电路用于约束特定的操作——例如,Keccak电路计算Keccak哈希,求幂电路计算求幂。我们的zkEVM电路设计中当前限制是每个子电路必须具有相同的行数,比如m行。
基于ZK Rollup的订单簿DEX DeGate正式上线主网Beta版本:5月3日消息,基于ZK Rollup的订单簿DEX DeGate正式上线主网Beta版本,此前DeGate进行早期采用者NFT通行证铸造活动,从主网Beta版本发布开始的首个星期,协议仅限DeGate NFT铸造者访问,之后将向公众开放。
此前报道,DeGate已通过Trail of Bits、Least Authority、Secbit多家审计机构的审计,同时与Immunefi合作推出的111万美元的漏洞赏金计划也正在进行中。[2023/5/4 14:40:52]
根据每个子电路中消耗的行数,每个所传入的交易都具有唯一的配置文件。例如,可能有一个交易需要许多Keccak操作,因此在Keccak电路中占用许多行,而在求幂电路中不占用任何行。相反,可能有一个交易在Keccak电路中占用很少的行,而在求幂电路中占用很多行。
Polygon正在对zk rollups技术进行性能测试:1月14日消息,Polygon正在对零知识汇总 (zk rollups) 技术进行性能测试。这项名为Polygon zkEVM技术的开发已经由Polygon Hermez团队进行了三年多。通过在zkEVM测试网的主要版本中生成超过12,000个zk证明,该团队已经确认零知识证明在以太坊上是可行的。(Cointelegraph)[2023/1/14 11:12:10]
由于批次由区块组成,而区块由交易组成,因此批次的行消耗配置文件由组成它的交易所决定。如果一个批次的行消耗超过最大行数m,则该批次将无法证明。当一个批次无法证明时,它无法在L1上最终确认,任何后续的批次也无法证明。
值得注意的是,即使只包含单个交易的批次也可能会溢出电路。
要解决“证明溢出”问题需要解决以下问题:如何防止创建超出电路容量的批次?
ZK Rollup扩容方案StarkNet Alpha上线以太坊主网:11月29日消息,StarkWare推出的以太坊Rollup扩容方案StarkNet Alpha今日上线以太坊主网。StarkNet是一个无需许可的以太坊L2网络去中心化Rollup扩容方案。StarkNet允许任何dApp实现其计算规模,而不会影响可组合性和安全性,它依赖于安全和具可扩展性的加密证明系统——STARK。StarkNet建立在Cairo编程语言之上,Cairo和STARK均由 StarkWare内部开发,并为生产级应用程序提供支持。除其他功能外,StarkNet Alpha支持通用计算智能合约,支持与其他StarkNet合约以及通过 L1长期解决方案
以太坊ZK Rollup扩容方案Hermez Network正在开源零知识证明模块:据官方消息,以太坊ZK Rollup扩容方案 Hermez Network表示,正在开发一个名为Rapidsnark新的zk-SNARKs零知识证明模块,目前已经发布并开放了源代码。[2021/2/2 18:43:40]
问题源于我们电路架构的局限性:所有子电路都必须有一些预先确定的、固定数量的行。我们正在研究重新设计我们的架构,以便可以独立地动态调整子电路的大小——每个子电路的大小都可以根据批次证明的要求放大或缩小。例如,如果一个批次在Keccak电路中需要2^20行,但在求幂电路中只需要2^14行,则子电路可以独立缩放。
这种类型的动态设计带来了挑战,我们正在努力解决这些问题。然而,与此同时,我们需要解决固定尺寸电路的问题。
当前解决方案
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限制,这样即使在最坏的情况下,强制交易也不会溢出电路。
从长远来看,我们的目标是开发一个更灵活的证明系统,支持动态大小的子电路,从而完全避免这个问题。
2023年5月6日,据Beosin-Eagle?Eye态势感知平台消息,算法稳定币DEI项目合约遭受黑客攻击,黑客获利约630万美元。Beosin安全团队第一时间对事件进行了分析,结果如下.
1900/1/1 0:00:00很多人在质疑,AIGC难以对传统的企业服务市场造成影响。但这两个月的发展表明,这种判断仍然为时过早。ERP、SaaS等传统企服花了几十年教育市场,至今,从业者们仍能回想起开拓客户之不易.
1900/1/1 0:00:00来源:橡果商业评论,作者:豚豚,编辑:赵翔 图片来源:由无界AI工具生成ChatGPT问世至今,互联上讨论声绵延不绝。有人说AI会替代基础性工作.
1900/1/1 0:00:002023年3月,推特用户@domodata为比特币创建的一个实验性Token标准,利用JSON数据的序号铭文,可以部署token、铸造和转移——也就是现在的BRC-20.
1900/1/1 0:00:00近日的市场热度令人焦虑,但真的这么多人在BRC-20上赚钱了吗?纵览推特,众多KOL号称在BRC-20大赚了一笔,纷纷分享心得,目前,领涨的ORDI?单价已突破27?美元.
1900/1/1 0:00:0012:00-21:00关键词:非农就业、PEPE、纽约总检察长、DCG1.美国4月非农就业人数增加25.3万人.
1900/1/1 0:00:00