ZKS:Layer2 系统的安全性和效率取舍

感谢?MatterLabs?提出关于部分L1数据链上可用性的问题,我们一直以来都非常重视社区的声音,并会根据社区的需求修改方案。因此,我们想借着这次机会向大家分享?ZKSwap?开发团队辛勤工作所交付的产品背后的一些思考。

经过非常谨慎细致的思考之后,为了TPS和Gasfee的效率,我们决定将ZKSwap的L2转账放在链下。在ZKSwap的设计中,L1相关的数据在链上,L2相关的数据,比如转账和交易,存在链下。尽管存在链下,这部分数据也会被验证者实时公布。

例如,L2区块7831:

https://api.zkswap.info/block/7831/pub-data

三种转账类型

ZK-Rollup协议中,一个区块可以包括三种类型的转账:

以太坊Layer 2上总锁仓量为89.5亿美元:金色财经报道,L2BEAT数据显示,截至目前,以太坊Layer2上总锁仓量为89.5亿美元,近7日涨29.39%。其中锁仓量最高的为扩容方案ArbitrumOne,约59.4亿美元,占比50.87%,其次是Optimism,锁仓量19.5亿美元,占比21.89%。[2023/3/30 13:34:58]

类型1:来自L1的存款和创建AMM交易对的转账;

类型2:L2发起且只能被L1验证的转账。比如,公钥转账将需要L1签名来确保L1账户的密钥所有者能将他们的账户与L2账户关联起来,因为电路不能检查确认L1的签名;

类型3:由L2签名验证而无法被L1验证的转账。

ZKSwap安全模型

一个区块内记录的L2转账在L1上只有部分记录。只有区块信息的总结会被记录在L1链上,例如区块哈希、新默克尔根、区块高度等等。

Layer 2 + DAO基础协议Metis宣布完成300万美元A轮融资:据官方消息,Layer 2 + DAO基础协议Metis今天宣布完成300万美元A轮融资,主要投资人包括Block Dream Fund, Genblock Capital, Cryptomeria Capital, ConsensusLab, PARSIQ, YBB Foundation, Flurry Capital, Chronos Ventures, Gate.io, 7 O’Clock Foundation, BMW Capital等。

同时,Metis宣布推出其自有的二层协议框架Metis Rollup以支持Web 3经济体的构建。与其他Optimistic Rollup 项目相比,Metis Rollup更具扩展性和去中心化,挑战验证期更短,支持与IPFS集成来保护隐私数据,并支持微服务框架来实现应用快速开发。同时,Metis将DAO的框架内置到二层协议之中,方便应用和社区快速部署、上线和管理各种去中心化的创新应用。

Metis的Alpha测试网将于近日上线,同时上线的还有基于Metis Rollup构建的第一个MVP产品——Prologue(序章),该产品可以让任何用户快速创建在Layer 2上的DAC(去中心化公司)。[2021/3/30 19:30:34]

当一个区块的转账被提交到L1上,区块就被创建出来,区块哈希会被验证。由于以太坊内建了sha256算法,所以区块哈希通常也使用sha256进行计算。

动态 | 新比特币改进提案(BIP)拟推出交易中继系统Erlay,将提升40%比特币带宽效率:据ccvalue消息,根据科学论文预印本网站arXiv披露的信息显示,一个全新的比特币交易中继系统Erlay开发人员正在与社区进行讨论并接收反馈,拟提交比特币改进提案(BIP)。该提案将提升比特币网络安全性、抵御试图学习交易起源节点的攻击。此外,随着连接性的增长,这个中继系统能够在确保贷款使用不变的条件下将带宽效率提高40%。据悉,该提案的主要想法是不是想每个peer广播每笔交易,而是仅通过少量链接直接发送一小部分链接(仅有8个外发连接),通过周期性地运行设置的协调协议来实现进一步的中继。提案中规定Erlay协议必须满足四个要求:1、必须能够很好地扩张,保持安全性和初始性能;2、协议必须是非结构化的,并且路由决策应该由独立节点在本地进行,这一要求有助于降低审查的可能性;3、协议应具有低延迟,以便为用户提供更快的体验;4、该协议应该与现有协议一样安全,以抵御DoS和去匿名攻击。[2019/5/28]

为了保持数据可用性,所有的转账数据都应该被提交到L1上,这被称为「公开数据」。一笔转账的公开数据与其在L2上的转账并不完全相同。系统在进入「退出模式」时将使用公开数据,这样任何人都能恢复最近的经过验证的默克尔树。

动态 | Google Play上发现EOS Rio虚假版本 现已被删除:据pymnts报道,EOS Rio(巴西节点)开发者警告用户有人试图在Google Play上传播其数字货币钱包应用程序的虚假版本。此虚假版本名为SimpIEOS,EOS Rio称已采取适当措施将该应用程序从Play商店中删除。[2018/11/9]

电路

L2的电路与L1的智能合约能够协同工作,确保ZK-Rollup协议的功能性。L2的电路保证了以下几点:L2转账签名正确、L1/L2转账执行正确、区块信息计算正确、及时有效地更新账户信息——包括默克尔根、账户默克尔树和费用信息等等。

双验证模式

验证模块对与安全性来说十分重要,是ZK-Rollup协议的基础。

公开数据验证——验证第一类和第二类转账的内容和次序。例如,验证存款需要确保存款数额和信息与L1上记录的相同,并且顺序无误。

区块验证——验证一个区块里的转账被正确执行,并且L2的账户默克尔树根被及时恰当地通过零知识证明进行更新。当一个区块被验证之后,更新的默克尔根就取得了最终性。

总结来说,整体的安全假设如下:

·一个区块的所有转账公开数据在链上;

·验证一个区块中第一类和第二类转账被正确执行;

·证明一个区块内的所有转账被正确执行、账户默克尔树被正确更新、一个区块内的所有转账的公开数据能够匹配;

·证明该区块内所有公开数据都被正确计算;

·提交给L1的区块公开数据与零知识证明系统所证明的数据相同。

公开数据不上链时会发生什么?

如果公开数据不在链上,安全假设「提交给L1的区块公开数据与零知识证明系统所证明的数据相同」就不能被验证。这时候,当L2的零知识证明系统阵营所有转账都被正确执行、默克尔树都被正确更新时,只能说明一个区块内的转账有效,而不能证明来自特定区块的其他转账。

大多数第三类转账都是安全的,但是对于提现操作来说,提现的收款人未经验证,不能被零知识证明系统证明。

对于第一类转账来说,所有可能的第一类转账都能被证明,但不能被验证。类如,零知识证明系统能证明一些非L1发起的存款转账。

由于只有验证着能提交公开数据或者区块证明,所以社区必须信任验证者是诚实的。当验证者诚实时,以上所有的风险都不会存在。对ZKSwap来说,所有公开数据都在浏览器中同步公布,任何人都可以验证公开数据和任何链上区块。

将公开数据存在链下不是一个草率的决定。这个选择背后的主要原因是降低Gas费和提高可扩展性。

Gas费用

保持ZK-Rollup协议运行的一个痛点是Gas。为了向L1提交一个区块,需要消耗以下GasLimit):

一个区块中,最多可以包括120笔交易转账。

如果要在L1提交验证一个区块,需要消耗大约23万GasLimit,calldata费用约占31%。

可扩展性

可扩展性是另一个考虑因素。假设一笔L2转账消耗1850.7Gas,那么ZKSwap将消耗10%的以太坊Gas,整体TPS将在51.5。

这是在只有交易、没有提现的情况,所以正常使用中将消耗更多Gas,TPS会更低。

结论

保护用户资金安全对所有区块链项目来说都很重要,也是ZKSwap的核心价值。当转账的公开数据没有提交上链时,安全性就依赖于零知识证明电路。当验证者诚实时,用户的资产就是安全的。从技术角度来说,如果验证者不诚实,安全性将会是一个问题。这是降低Gas、提高TPS的一个权衡。

考虑到Gas消耗和可扩展性,ZKSwap做了一个艰难的决定,将公开数据不上链,换来对L2用户更高的TPS和更低的Gas消耗。

我们愿意倾听开发者和用户的反馈,让ZKSwap系统更好。我们也可以在任何时间将所有数据上链。事实上,在发布ZKSwap之前,我们已经实现了100%数据可用的版本,所以我们可用随时升级至这个100%ZK-Rollup的版本,提供更高的Gas消耗、更低的TPS,但是更安全。

郑重声明: 本文版权归原作者所有, 转载文章仅为传播更多信息之目的, 如作者信息标记有误, 请第一时间联系我们修改或删除, 多谢。

金星链

[0:0ms0-1:712ms