许多克服区块链可扩展性的方案都错误地聚焦在增加吞吐量,然而,这忽视了吞吐量对节点的影响:为了处理区块和存储网络历史,升级硬件需求会越来越强烈,进而阻碍了一个网络的去中心化。
区块链可扩展性一直是一个热门话题。几乎每一个区块链网络把TPS(每秒交易量)作为一个卖点,然而,TPS不是一个对比不同区块链网络的有效指标,会给评估不同区块链之间的相对性能带来挑战。此外,高TPS通常会带来高成本,由此就引发一个问题:这些网络实际上真的可以扩展,或者说它们仅仅增加了它们的吞吐量?
为了回答这个问题,让我们看看如何定义可扩展性,为了实现它需要进行的权衡,以及为什么ValidityRollups是最终极的可扩展性解决方案。
并非所有的交易都是相同的
首先,我们需要声明我们的主张,简便的TPS指标不是一个精确的衡量可扩展性的标准。
为了对节点执行交易进行补偿,同时也为了阻止用户通过发送不必要的交易攻击网络,区块链会根据链上的计算负担按比例收取费用。以太坊网络中,计算负担的复杂性用gas费用来衡量。因为gas是一个针对交易复杂性非常简便的度量,这个术语也将在本文中用于非以太坊的区块链,即使它一般特定于以太坊的。
交易在复杂性上有巨大的不同,因此,消耗的gas也是不同的。比特币是最早实行无需信任的点对点交易,但是只支持基本的比特币脚本。这些地址与地址之间简单的转移只使用很少的gas。相反,像以太坊或者Solana这样的智能合约链支持虚拟机和图灵完备编程语言,能够实现更加复杂的交易。因而,像Uniswap这类dApps需要更多的gas费。
美国参议院允许弗吉尼亚州银行提供加密托管服务:3月5日消息,美国参议院允许弗吉尼亚州银行提供加密托管服务。美国参议院一致批准了一项法案修正案请求,该请求现在允许在弗吉尼亚联邦运营的传统银行提供虚拟货币托管服务。代表Christopher T. Head早在2022年1月就提出了该法案(众议院第263号法案),寻求修正案,允许符合条件的银行提供加密货币托管服务,“只要银行有26项适当的协议来有效管理风险并遵守适用法律,银行就可以向客户提供虚拟货币托管服务。”
该法案以39票对0票席卷在参议院获得通过,正在等待弗吉尼亚州州长格伦·杨金签署成为法律。打算向客户提供这项服务的银行需要遵守法案中提到的三项具体要求——实施有效的风险管理系统,拥有足够的保险范围,并启动监督计划来解决与加密货币相关的风险。
然而,参议院将要求银行的客户保留对其虚拟货币关联的公钥和私钥的直接控制权,并补充说:
“银行应以信托身份行事,要求客户通过创建由银行持有的新私钥,将其虚拟货币移交给银行控制。”(Cointelegraph)[2022/3/5 13:39:39]
这也是为什么比较不同区块链TPS没有意义,我们应该比较的是计算能力或者说是吞吐量。
所有的区块链有可变的区块大小和区块时间,它们决定了每个块可以处理多少计算单元以及添加新区块的速度。这两个变量决定了一个区块链的吞吐量。
美国参议院民主党人公布了3.5万亿美元的预算计划:8月9日消息,国会文件显示,美国参议院民主党人周一公布了3.5万亿美元的预算计划,文件要求税收减免和拨款,以鼓励“清洁能源”制造业和运输业的发展,同时对移民和教育政策进行重大改革。拟议的预算决议旨在执行总统美国总统拜登3.5万亿美元的“人类基础设施”倡议。民主党人打算在未来几天就这项不具约束力的决议进行辩论并通过该计划。这份计划将作为今年晚些时候更详细、具有约束力的立法的框架。[2021/8/9 1:44:21]
什么限制了可扩展性
区块链发展方向是实现最大化的去中心化、包容性的网络。在实现这一目标过程中,会受制于两个基本的属性:硬件、状态。
硬件要求
一个去中心化的区块链网络由网络中最弱的节点验证这个区块链和保持状态的能力决定的。因此,运行一个节点成本应该尽可能地降低,以使尽可能多的人成为去信任网络无需许可的参与者。
状态增长
状态的增长是指区块链增长的速度。一个区块链在每单位时间允许越多的吞吐,这个区块链增长的就越快。全节点存储网络历史,同时它们也必须能够验证网络状态。通过使用树状等高效结构,以太坊的网络状态被储存和引用。随着状态增长,新的“叶子”和“分枝”被添加进去,使得其执行特定的行为时会更加复杂和消耗更多的时间。随着链的规模增长,节点在最坏情况下的执行会变得更糟糕,从而导致验证新块的时间不断增加。随着时间的增加,这也增加了全节点同步所需要的总时间。
比特币倡导者Cynthia Lummis将担任美国参议院银行委员会委员:2月4日消息,美国怀俄明州参议院议员、比特币倡导者Cynthia Lummis将在美国参议院银行业委员会任职。就在此前2月2日,Cynthia Lummis曾表示,将启动金融创新核心小组,以对其他参议员进行比特币教育,普及加密货币和数字资产,并纠正加密货币是被用于的工具的错误说法。(Crypto Potato)[2021/2/4 18:54:43]
增加吞吐量的不利影响
节点数
运行节点的最低要求和节点数:
比特币: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、带宽和存储要求越高,该区块链网络上能够参与的节点就越少,从而导致去中心化和包容性就越弱。
同步全节点需要的时间
当第一次运行一个全节点时,它需要同步所有的现有节点,下载并验证从创始区块到链前端的网络状态。这个过程应该尽可能的快速和高效,以允许任何人作为这个无需许可的协议的参与者。
动态 | John McAfee推出新应用程序Bitcoin Play:5月5日,John McAfee发推宣布推出一款名为“Bitcoin Play”的新应用程序,该应用提供家庭友好选项及成人友好选项两个版本,用户可通过回答“挑战性的多项选择题”来测试其历史、体育、娱乐等类别的知识储备,在回答问题的同时可赚取比特币。[2019/5/6]
以JamesonLopp的2020年比特币节点和2021年节点同步测试为参照,表1中对比了比特币、以太坊、Solana在普通消费级电脑上同步一个全节点所需要的时间。
表1区块链吞吐和节点同步比较
表1呈现了增加吞吐量会导致更长的同步时间,因为更多的数据需要被处理和存储。
虽然区块链可以通过不断改进节点软件以缓解不断增长的区块链挑战,比如降低磁盘的占用空间、更快的同步速度、更强的崩溃恢复能力、某些组建的模块化等等,但是很显然节点无法跟上吞吐量增加的步伐。
可扩展性应该如何被定义
可扩展性是区块链领域最被误解的术语。虽然增加吞吐量是可取的,但是这只是该难题的一部分。
可扩展性意味着在相同的硬件上进行更多的交易。因此,可扩展性可以分为两大类:排序可扩展性、验证可扩展性。
排序可扩展性
分析 | 新增代币型智能合约FRONT、SWAP和EplayG风险最高:区块链项目评级机构RatingToken最新数据显示,2018年7月15日全球共新增3179个合约地址,其中206个为代币型智能合约。RatingToken发布的“新增代币型智能合约风险榜”中,FRONT、SWAP和EplayG风险最高,检测得分分别为2.64、2.90和2.92。其他登上该风险榜TOP10的还包括DTP、LIGHT、APAM、TKWY、ZTK、TIA、GRT。如需查询检测结果请访问RatingToken官网。[2018/7/16]
排序描述了网络中对交易进行排序和处理的行为。如前所述,任何区块链可以增加区块空间和缩短出块时间来小幅增加吞吐量,一直到这种方法对区块链去中心化产生显著的影响。但是,调整这些简单的参数提供的改进是有限的。理论上,以太坊虚拟机能够实现高达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
来源:金色财经
郑重声明: 本文版权归原作者所有, 转载文章仅为传播更多信息之目的, 如作者信息标记有误, 请第一时间联系我们修改或删除, 多谢。