Layer2扩容存误区 重新定义可扩展性_COIN:COI

许多克服区块链可扩展性的方案都错误地聚焦在增加吞吐量,然而,这忽视了吞吐量对节点的影响:为了处理区块和存储网络历史,升级硬件需求会越来越强烈,进而阻碍了一个网络的去中心化。

区块链可扩展性一直是一个热门话题。几乎每一个区块链网络把TPS(每秒交易量)作为一个卖点,然而,TPS不是一个对比不同区块链网络的有效指标,会给评估不同区块链之间的相对性能带来挑战。此外,高TPS通常会带来高成本,由此就引发一个问题:这些网络实际上真的可以扩展,或者说它们仅仅增加了它们的吞吐量?

为了回答这个问题,让我们看看如何定义可扩展性,为了实现它需要进行的权衡,以及为什么ValidityRollups是最终极的可扩展性解决方案。

并非所有的交易都是相同的

首先,我们需要声明我们的主张,简便的TPS指标不是一个精确的衡量可扩展性的标准。

为了对节点执行交易进行补偿,同时也为了阻止用户通过发送不必要的交易攻击网络,区块链会根据链上的计算负担按比例收取费用。以太坊网络中,计算负担的复杂性用gas费用来衡量。因为gas是一个针对交易复杂性非常简便的度量,这个术语也将在本文中用于非以太坊的区块链,即使它一般特定于以太坊的。

交易在复杂性上有巨大的不同,因此,消耗的gas也是不同的。比特币是最早实行无需信任的点对点交易,但是只支持基本的比特币脚本。这些地址与地址之间简单的转移只使用很少的gas。相反,像以太坊或者Solana这样的智能合约链支持虚拟机和图灵完备编程语言,能够实现更加复杂的交易。因而,像Uniswap这类dApps需要更多的gas费。

Coinbase平台交易已恢复:金色财经报道,Coinbase在其状态页上报告称,目前交易已恢复。除了投资组合余额目前处于降级状态之外,所有服务均正常。Coinbase正在继续解决此问题。[2021/1/30 14:22:48]

这也是为什么比较不同区块链TPS没有意义,我们应该比较的是计算能力或者说是吞吐量。

所有的区块链有可变的区块大小和区块时间,它们决定了每个块可以处理多少计算单元以及添加新区块的速度。这两个变量决定了一个区块链的吞吐量。

什么限制了可扩展性

区块链发展方向是实现最大化的去中心化、包容性的网络。在实现这一目标过程中,会受制于两个基本的属性:硬件、状态。

硬件要求

一个去中心化的区块链网络由网络中最弱的节点验证这个区块链和保持状态的能力决定的。因此,运行一个节点成本应该尽可能地降低,以使尽可能多的人成为去信任网络无需许可的参与者。

状态增长

状态的增长是指区块链增长的速度。一个区块链在每单位时间允许越多的吞吐,这个区块链增长的就越快。全节点存储网络历史,同时它们也必须能够验证网络状态。通过使用树状等高效结构,以太坊的网络状态被储存和引用。随着状态增长,新的“叶子”和“分枝”被添加进去,使得其执行特定的行为时会更加复杂和消耗更多的时间。随着链的规模增长,节点在最坏情况下的执行会变得更糟糕,从而导致验证新块的时间不断增加。随着时间的增加,这也增加了全节点同步所需要的总时间。

MXC抹茶10月15日上线Filecoin,并支持FIL6代币转换为FIL代币:据官方公告,MXC抹茶10月15日上线Filecoin(FIL),并支持Filecoin主网上线和支持FIL6按每天线性解锁的方式释放流通量,每天为FIL6持仓用户进行约0.55%的FIL6代币转换,届时将转换为FIL代币。

据Filecoin(FIL)消息,Filecoin主网将于148,888区块高度正式开启,预计时间为10月15日。[2020/10/10]

增加吞吐量的不利影响

节点数

运行节点的最低要求和节点数:

比特币: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、带宽和存储要求越高,该区块链网络上能够参与的节点就越少,从而导致去中心化和包容性就越弱。

同步全节点需要的时间

Bitcoin Advisory创始人:同步ETH节点所花时间远超BTC节点:金色财经报道,比特币咨询公司Bitcoin Advisory创始人Pierre Rochard今日发推文称,ETH的价值远低于BTC,但同步一个以太坊节点花的时间要比同步一个比特币节点长得多。[2020/8/15]

当第一次运行一个全节点时,它需要同步所有的现有节点,下载并验证从创始区块到链前端的网络状态。这个过程应该尽可能的快速和高效,以允许任何人作为这个无需许可的协议的参与者。

以JamesonLopp的2020年比特币节点和2021年节点同步测试为参照,表1中对比了比特币、以太坊、Solana在普通消费级电脑上同步一个全节点所需要的时间。

表1区块链吞吐和节点同步比较

表1呈现了增加吞吐量会导致更长的同步时间,因为更多的数据需要被处理和存储。

虽然区块链可以通过不断改进节点软件以缓解不断增长的区块链挑战,比如降低磁盘的占用空间、更快的同步速度、更强的崩溃恢复能力、某些组建的模块化等等,但是很显然节点无法跟上吞吐量增加的步伐。

可扩展性应该如何被定义

可扩展性是区块链领域最被误解的术语。虽然增加吞吐量是可取的,但是这只是该难题的一部分。

可扩展性意味着在相同的硬件上进行更多的交易。因此,可扩展性可以分为两大类:排序可扩展性、验证可扩展性。

声音 | OKcoin副总裁徐坤:溯源成本、技术研发速度是决定落地速度的两大问题:OKcoin副总裁徐坤在微博针对“中共中央、国务院发布关于深化改革加强食品安全工作的意见”表示:区块链技术去中心化、可追溯、不可篡改等特性可有效解决食品安全溯源问题,保障食品从生产、出厂、运输到销售等一系列流程都有据可查、真实可信,有利于建立更为完善的食品安全体系。目前溯源成本、技术研发速度是决定落地速度的两大问题,大规模发展有赖于国家从战略层面推动。这个文件就是信号。[2019/5/21]

排序可扩展性

排序描述了网络中对交易进行排序和处理的行为。如前所述,任何区块链可以增加区块空间和缩短出块时间来小幅增加吞吐量,一直到这种方法对区块链去中心化产生显著的影响。但是,调整这些简单的参数提供的改进是有限的。理论上,以太坊虚拟机能够实现高达2000TPS,但是长期而言,还不能满足区块空间的需求。

为了扩展排序,Solana做了一些令人印象深刻的创新:利用了可并行化的执行环境和巧妙的共识机制,从而实现了更加高效的吞吐量。不过,尽管它有所提升,但这种方式既不充分,也不可扩展。随着Solana增加了自身的吞吐量,运行节点和处理交易的硬件成本也在增加。

验证可扩展性

验证扩展性描述了增加吞吐量而不用持续增加硬件成本的节点负担的方法。具体来说,它指的是像Validityproofs的密码学创新。它们是ValidityRollups可以可持续扩展一个区块链的原因。

动态 | Kakao已推出Klaytn的区块链测试网络:据coindesk消息,Ground X是韩国消息传递巨头Kakao的区块链开发部门,已经推出了其专有区块链网络Klaytn的测试网络(testnet)。该公司表示,该网络现已向10个受邀合作伙伴提供。它还发布了一份白皮书,提供该平台的详细信息,旨在为分散的应用程序或dapps奠定技术基础。[2018/10/8]

什么是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

来源:金色财经

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

金智博客

[0:15ms0-2:843ms