最近疯狂的铭文运动是对各大公链的一次大考,有的公链宕机,有的公链手续费爆炸上涨,在这一次大考中,zkSync 无论是性能,还是GAS稳定性等都完美经受了考验。
你或许会疑惑,zkSync 不是因为铭文宕机了么,真相是,这是由于区块链浏览器前端显示出现了问题,本文从技术原理的角度出发解释了为何zkSync性能卓越,为何处理的交易量越大,Gas费则越便宜。
在zkSync链上刻铭文,短时涌入的天量交易,确实是一次layer2公链性能的“压力测试”,不过结果并非“宕机”,恰恰相反,这是一次zkSync的公开练兵,结果是TPS峰值、GAS稳定性等都完美经受了考验。
乍一听,是不是有点反直觉?接下来,用技术逻辑,我来给大家澄清一下:
zkSync打包出块的工作原理,简单而言:用户构造交易进入zkSync Sequencer的排序序列,然后Sequencer根据Gas Fee高低排序打包进区块,然后再把区块传入Proof系统验证,最后Submit到主网完成finality状态确认
1)用户构造交易环节:大部分用户都会通过Metamask等钱包端发起交易,而通过钱包端向zkSync发交易,交易会先进入RPC远程调用服务器里,然后Sequencer接收这些交易进入排队序列。这里的排队时间短则几秒,长则几分钟,人如果等待时间较长,MetaMask就会认定该笔交易已经失败,然后前端返回交易失败的提示。
然而,这并不意味着交易真失败了,而只是因为Metamask的RPC响应时间和反馈逻辑和zkSync的Sequencer排队打包交易逻辑存在“不兼容”所致。这正是为何,一些明明MetaMask显示失败的交易,在等待一段时间后,后端服务器显示又成功的原因。
如果用户不走钱包管道,直接使用后端代码调用zkSync的RPC,就不会存在响应时间超时以及提示失败的问题,体验相对而言会很丝滑。这确实会让一些可使用后端代码指令的“科学家”取得了优势,但本质上属于钱包体验端的问题,和zkSync链的处理能力无关。
2)Sequencer公平排序环节:当用户短时向RPC队列发出交易时,每一笔交易都会从nonce值为0开始叠加,如果上一笔交易还在排队状态,nonce为0,这时用户又发起了一笔新交易nonce为1,zkSync的Sequencer会根据time来给这些交易分配nonce,然后按照顺序排序。
但倘若,用户在MetaMask前段看到上一笔交易显示失败后,同时又提交新的交易,很可能新提交的交易由于钱包端和zkSync API接口调用的问题,有一部分交易最终并没有成功提交到RPC的排队序列中。用户以为提交了很多交易,实际上zkSync只收到了其中一部分,而只要他们收到就会去排序处理。
这么看,用户看到MetaMask反馈交易失败,不停提交新交易的行为也会造成大量交易失败,因为根本就没有提交到zkSync链的后端,只是你在前端以为自己提交了。
整体而言,MetaMask钱包的RPC响应时间逻辑问题和用户着急向链上叠加交易的行为,都会造成大量的交易“失败”,如果清楚zkSync的后台交易处理工作流程的话,相对更容易避开这些优化体验问题。
zkSync链并未“宕机”,只是浏览器前端显示问题,因为浏览器会通过zkSync的RPC接口拉取最新数据,但是接口响应会有延迟,大量新交易会使响应变慢。
总之,浏览器的拉取数据同步速度跟不上排队交易激增的速度,这是浏览器前端的问题,与链的运转没有关系。通常等交易速度适当放缓,浏览器可以抓取到新数据后,问题就会解决。
当遇到浏览器不work的时候,可以通过其他同步zkSync区块数据信息的浏览器来交叉验证。
1)在所谓宕机传闻爆出后,zkSync的官方工作人员Anthony Rose在推特却频频发出TPS刷新捷报。实际上,zkSync TPS飙到了187.9的峰值,正常情况下,TPS只有50-100左右,这说明大量的新交易涌入,zkSync其实抗住了压力。这确实也给未来数千甚至上万的TPS做了一次充分的“压力测试”。
2)ZK-Rollup的特殊机制决定了,处理的交易量越大,Gas费则越便宜,事实上,zkSync的Gas费确实更加便宜了,因为交易成本也被分摊了,根据growthepie数据显示,近24小时,zkSync的Gas平均值还降低了5.2%,平均在$0.19左右,这个数据每个人的体验可能不一样,但综合链的运行数据,确实是便宜了。佐证了ZK-Rollup的更流畅体验需要将现有的用户规模提升一个量级。
根据dune数据显示, Sync的铭文铸造,14个小时新增了5M笔交易,已有65575个Holder参加。诚如上述所言,zkSync官方已经知道了这场社区发起的“压力测试”活动,还紧急采取措施来确保zkSync链的有序进行。
这个数据对zkSync而言确实是一次较好的压力测试实验,其正向影响大于负面。长远看,铭文事件并非传言中把layer2性能打回了原型,反倒给layer2的进一步性能优化提供了实践经验。
不过据我了解,除了Sync之外,还有其他铭文正在铸造,虽不及Sync那么fomo,但也给此压力测试添了一把火。
Anyway,结果总体而言是好的,大家若厘清zkSync后台排序出块的技术逻辑,再拨开其中存在的“体验糟糕”误会,就应该懂得,一切运行安好,我们得给layer2多一点信心。
来源:金色财经