许多克服区块链可扩展性的方案都错误地聚焦在增加吞吐量,然而,这忽视了吞吐量对节点的影响:为了处理区块和存储网络历史,升级硬件需求会越来越强烈,进而阻碍了一个网络的去中心化。
区块链可扩展性一直是一个热门话题。几乎每一个区块链网络把TPS(每秒交易量)作为一个卖点,然而,TPS不是一个对比不同区块链网络的有效指标,会给评估不同区块链之间的相对性能带来挑战。此外,高TPS通常会带来高成本,由此就引发一个问题:这些网络实际上真的可以扩展,或者说它们仅仅增加了它们的吞吐量?
为了回答这个问题,让我们看看如何定义可扩展性,为了实现它需要进行的权衡,以及为什么ValidityRollups是最终极的可扩展性解决方案。
并非所有的交易都是相同的
首先,我们需要声明我们的主张,简便的TPS指标不是一个精确的衡量可扩展性的标准。
为了对节点执行交易进行补偿,同时也为了阻止用户通过发送不必要的交易攻击网络,区块链会根据链上的计算负担按比例收取费用。以太坊网络中,计算负担的复杂性用gas费用来衡量。因为gas是一个针对交易复杂性非常简便的度量,这个术语也将在本文中用于非以太坊的区块链,即使它一般特定于以太坊的。
交易在复杂性上有巨大的不同,因此,消耗的gas也是不同的。比特币是最早实行无需信任的点对点交易,但是只支持基本的比特币脚本。这些地址与地址之间简单的转移只使用很少的gas。相反,像以太坊或者Solana这样的智能合约链支持虚拟机和图灵完备编程语言,能够实现更加复杂的交易。因而,像Uniswap这类dApps需要更多的gas费。
法官裁决Ripple部分是证券 SEC诉Ripple案将进入审判阶段:金色财经报道,2023年7月13日美国纽约南区地区法院法官就SEC诉Ripple案作出简易判决(summary judgement?),在法官的判决中,SEC和Ripple的动议均部分获得批准,部分被否决。法官判决指出:“在考虑了经济现实和机构销售的总体情况后,法院得出结论,Ripple 的 XRP 机构销售构成了未经注册证券的投资合约和销售,违反了《证券法》第 5 条。”“考虑到经济现实和总体情况,法院得出结论,Ripple 对 XRP 的程序化销售、其他分配以及Larsen和Garlinghouse的销售不构成投资合约和销售。”?根据法院判决文件,SEC诉Ripple案将进入审判阶段。纽约南区地区法院表示,将在适当的时候另行发布命令,确定审判日期和相关的审前期限。此前市场传闻,Ripple赢得XRP不是证券的判决,消息传出后XRP短时涨幅超23%。[2023/7/14 10:53:48]
这也是为什么比较不同区块链TPS没有意义,我们应该比较的是计算能力或者说是吞吐量。
所有的区块链有可变的区块大小和区块时间,它们决定了每个块可以处理多少计算单元以及添加新区块的速度。这两个变量决定了一个区块链的吞吐量。
什么限制了可扩展性
区块链发展方向是实现最大化的去中心化、包容性的网络。在实现这一目标过程中,会受制于两个基本的属性:硬件、状态。
加密交易所Bitbns:“用户余额为零”系隔夜数据库升级故障:金色财经报道,今日部分投资者发现自己在 印度交易所 Bitbns 上的账户显示为零并引发恐慌,不过 Bitbns 在官推澄清,“用户余额为零”系隔夜数据库升级故障导致,该交易所首席执行官 Gaurav Dahake 称其是一个“小技术故障”而且目前已经得到解决,一些用户确认他们的帐户已开始反映正确的余额。另据该交易所网站称,虽然用户余额应该已经恢复,但存款和提款需稍后才能恢复。(cryptoslate)[2023/6/28 22:04:13]
硬件要求
一个去中心化的区块链网络由网络中最弱的节点验证这个区块链和保持状态的能力决定的。因此,运行一个节点成本应该尽可能地降低,以使尽可能多的人成为去信任网络无需许可的参与者。
状态增长
状态的增长是指区块链增长的速度。一个区块链在每单位时间允许越多的吞吐,这个区块链增长的就越快。全节点存储网络历史,同时它们也必须能够验证网络状态。通过使用树状等高效结构,以太坊的网络状态被储存和引用。随着状态增长,新的“叶子”和“分枝”被添加进去,使得其执行特定的行为时会更加复杂和消耗更多的时间。随着链的规模增长,节点在最坏情况下的执行会变得更糟糕,从而导致验证新块的时间不断增加。随着时间的增加,这也增加了全节点同步所需要的总时间。
Reddio上线StarkEx提供支持的zkRollups API主网:9月29日消息,区块链基础设施服务商Reddio宣布,上线由StarkWare扩容引擎StarkEx提供支持的zkRollup API主网。Reddio表示,开发人员可以使用Reddio在zkRollup上构建应用内和游戏内NFT市场、扩展应用和游戏资产交易、使用Javascript SDK和Unity SDK以0 Gas费铸造NFT等,具有低Gas费用和即时确认等特点。[2022/9/29 6:01:45]
增加吞吐量的不利影响
节点数
运行节点的最低要求和节点数:
比特币:350GB硬盘空间、5Mbit/s连接、、1GBRAM、CPU>1Ghz。节点数:~10,000
Ethereum2:500GB+SSD磁盘空间,25Mbit/s连接,4-8GBRAM,CPU2-4核。节点数:~6,000
Solana3:1.5TB+SSD磁盘空间,300Mbit/s连接,128GBRAMCPU12+核。节点数:~1,200
可以发现,一个区块链吞吐量所需要的节点的CPU、带宽和存储要求越高,该区块链网络上能够参与的节点就越少,从而导致去中心化和包容性就越弱。
同步全节点需要的时间
米兰街头出现巨型比特币海报:“你所有的欧元都将归零”:金色财经报道,意大利米兰街头出现巨型比特币海报,海报内容一部分是几个大字写着“你所有的欧元都将归零”,另一部分是比特币论坛相关内容和二维码。[2022/10/15 14:29:01]
当第一次运行一个全节点时,它需要同步所有的现有节点,下载并验证从创始区块到链前端的网络状态。这个过程应该尽可能的快速和高效,以允许任何人作为这个无需许可的协议的参与者。
以JamesonLopp的2020年比特币节点和2021年节点同步测试为参照,表1中对比了比特币、以太坊、Solana在普通消费级电脑上同步一个全节点所需要的时间。
表1区块链吞吐和节点同步比较
表1呈现了增加吞吐量会导致更长的同步时间,因为更多的数据需要被处理和存储。
虽然区块链可以通过不断改进节点软件以缓解不断增长的区块链挑战,比如降低磁盘的占用空间、更快的同步速度、更强的崩溃恢复能力、某些组建的模块化等等,但是很显然节点无法跟上吞吐量增加的步伐。
可扩展性应该如何被定义
可扩展性是区块链领域最被误解的术语。虽然增加吞吐量是可取的,但是这只是该难题的一部分。
可扩展性意味着在相同的硬件上进行更多的交易。因此,可扩展性可以分为两大类:排序可扩展性、验证可扩展性。
派盾:孙宇晨一地址将1.64亿枚USDC转账至Circle:10月14日消息,据派盾预警监测,标记为孙宇晨的0x611F开头的地址将164,000,000枚USDC转账至Circle。此外,孙宇晨另一个以0x3Dd开头的地址已从Aave Protocol V2 中提取约2000万美元的TUSD并转移到币安。[2022/10/14 14:27:26]
排序可扩展性
排序描述了网络中对交易进行排序和处理的行为。如前所述,任何区块链可以增加区块空间和缩短出块时间来小幅增加吞吐量,一直到这种方法对区块链去中心化产生显著的影响。但是,调整这些简单的参数提供的改进是有限的。理论上,以太坊虚拟机能够实现高达2000TPS,但是长期而言,还不能满足区块空间的需求。
为了扩展排序,Solana做了一些令人印象深刻的创新:利用了可并行化的执行环境和巧妙的共识机制,从而实现了更加高效的吞吐量。不过,尽管它有所提升,但这种方式既不充分,也不可扩展。随着Solana增加了自身的吞吐量,运行节点和处理交易的硬件成本也在增加。
验证可扩展性
验证扩展性描述了增加吞吐量而不用持续增加硬件成本的节点负担的方法。具体来说,它指的是像Validityproofs的密码学创新。它们是ValidityRollups可以可持续扩展一个区块链的原因。
什么是ValidityRollup?
ValidityRollups把计算和状态存储迁移到链下,但是把一小部分的确定的数据放到链上。区块链底层上,有一个智能合约维护Rollup的状态根。在Rollup上,一批高度压缩的交易和当前的状态根一起被发送到链下证明者。这个证明者计算交易,对结果和新的状态根产生一个有效性证明,并且把它发送到链上的验证者。这个验证者验证有效性证明,维护Rollup状态的智能合约把由证明者提供的证明信息更新到新的状态。
ValidityRollups如何在硬件要求相同的情况下实现可扩展?
即使证明者确实需要高端的硬件,它们也不会影响一个区块链的去中心化;因为,交易的有效性被数学可验证的证明保证。
重要的是验证证明的要求。因为参与的数据被高度压缩并且很大程度上通过计算抽象出来,它对底层区块链节点的影响是很小的。
验证者不需要高端的硬件,批次的大小不会增加硬件需求。仅仅状态转换和小部分的数据响应需要被节点处理和存储。这允许了所有的以太坊节点通过现有的硬件验证ValidityRollup的批次。
交易越多,价格越便宜
一般来说,区块链上的交易越多,对于每个人来说就越贵。因为,随着区块空间被填满,用户需要在一个自由市场中出价高于他人,才能使得其交易被包含进区块。
对一个ValidityRollup来说,这样的情况是相反的。在以太坊上验证一批交易是有一定的成本。随着一个批次内的交易量增长,验证该批次的成本以指数形式缓慢降低。也就是说,增加更多的交易到一个批次会实现更便宜的交易费用,即使该批次的验证费用在增加。ValidityRollups希望在一个批次里面有尽可能多的交易,这样,验证费用可以由所有的交易者分摊。随着批次内规模无限增长,每一次交易费无限接近于零。在ValidityRollup上越多的交易,对每个人来说,就越便宜。
dYdX是由ValidityRollup提供支持的dAPP,经常会看到一个批次内有超过12000笔交易。可以把ValidityRollup和在主网上相同交易量的gas消耗进行对比,就可以看出降低成本的好处。
在以太坊主网上处理dYdX一次交易:200,000gas
在StarkEx上处理dYdX一次交易:<500gas
从另外一个视角看:ValidityRollups的主要成本与同一批次内部的用户数量呈现线性关系。
为什么OptimisticRollups不像人们想象中那样提供可扩展性
理论上,OptimisticRollups提供和ValidityRollups一样提供几乎一样的可扩展性优势。但是,有一个重要的区别:OptimisticRollups对平均情况进行优化,然而,ValidityRollups对最差的情况进行优化。因为区块链系统在不稳定的环境下运行,针对最差情况进行优化是仅有的方式实现安全性。
在OptimisticRollup最差的环境中,欺诈验证者不会检查用户交易。所以,为了对抗欺诈,用户需要同步一个以太坊全节点,一个L2全节点,并且需要自己计算可疑交易。
在ValidityRollup最差环境中,一个用户将仅需要同步一个以太坊全节点来验证有效性证明,为自己节省了计算负担。
和ValidityRollups不同,OptimisticRollups的成本随着交易量成线性关系,而不是用户数量,这会让它们会更贵。
难题的最后一部分——无需许可的获取Rollup状态
为了保证交易的有效性,用户仅需要运行一个以太坊节点。然而,用户和开发者因为各种目的想要查看和运行Rollup的状态和运行情况。一个索引L2节点可以完美满足这一需求。它不仅允许用户看到网络中的交易,而且,还是生态系统基础设施运行所必需的关键基础设施。像TheGraph、Alchemy、Infura等索引器,像Chainlink等预言机,像区块链浏览器,所有这些都是全部由一个无需许可的、索引L2节点支持。
结论
许多克服区块链可扩展性的方案都错误地聚焦在增加吞吐量,然而,这忽视了吞吐量对节点的影响:为了处理区块和存储网络历史,升级硬件需求会越来越强烈,进而阻碍了一个网络的去中心化。
随着加密学Validity-proof的出现,一个区块链能够实现真正的可扩展性,不会因为每次升级的成本给节点带来负担,允许更加广泛的去中心化。对于相同的硬件,现在可以使用更强大、更复杂的计算进行更多交易,从而在此过程中扭转费用市场的困境。ValidityRollup上的活动越多,它就越便宜。
文/StarkWare翻译/JackYang
来源:金色财经
郑重声明: 本文版权归原作者所有, 转载文章仅为传播更多信息之目的, 如作者信息标记有误, 请第一时间联系我们修改或删除, 多谢。