链资讯 链资讯
Ctrl+D收藏链资讯
首页 > BNB > 正文

如何衡量一条区块链的性能?Solana等区块链的“高TPS”口号已经无用了?

作者:

时间:

多链现在已成为现实。以太坊缺乏可扩展性导致大规模迁移到新一代 L1。这些 L1 中的大多数使用 EVM(以太坊虚拟机),这使得它们与以太坊钱包和开发工具兼容。但是 Solana 已经从头开始完全重建了它的堆栈。 Solana 声称是现有最快的区块链。所以它引出了一个问题:Solana 比 EVM 链快多少?

L1 区块链的 TVL 增长,图片来源:The Block

首先,我们需要就如何衡量性能达成一致。自古以来,新的区块链就一直在宣称它们的性能比以太坊高出多少。这是一种老调常谈。你会看到大量的数字和匆忙组合的图表,比较自我报告的 TPS(每秒交易量)。不幸的是,这些 TPS 数字通常来自他们自己的营销材料,而这些材料几乎都是废话。

L1 本身发布的大多数基准测试都测量简单价值转移的 TPS——即,将币从一个账户转移到另一个账户。简单的转账非常便宜,因此会产生庞大的数字,每个人都喜欢庞大的数字。但实际上没有区块链在这样的传输上遇到瓶颈,而且这种活动并不能反映现实世界的使用模式。此外,其中许多数字是在开发网络或测试网络上生成的,而不是在主网上生成的。我们不关心某人的软件抽象地可以做什么:我们关心当前主网上的可能性。

实际上,没有一种统一的方法来对 TPS 进行基准测试。基准测试中经常出现这种情况。这是一个混乱而令人担忧的领域,充满了误导性营销、过度拟合/“应试教学”和作弊。

好的。那么我们应该如何实际测量 L1 性能呢?

这是一个棘手的问题,因为性能有多个维度。

首先,性能始终是针对去中心化的一个妥协。与主网环境相比,高度中心化的测试网和开发网可以产生难以置信的数字。许多主网在去中心化方面偷工减料,这挤压了额外的性能。

但是,假设我们想忽略去中心化,只关注性能。好吧,众所周知,对区块链性能进行基准测试非常困难,因为大多数新链的数据可见性都很差。

7 年来,以太坊的性能得到了高度的研究和很好的理解。但是当你开始探索更新的链时,它们中的大多数工具都少得多,可观察性差,而且还在不断发展。当您阅读本文时,这些基准可能已经过时了。

此外,基准测试总是随意的,并且充满了陷阱。你能做的最好的就是选择一个衡量有价值的东西的基准,然后尽可能仔细地确定你的结果。这就是我们将在这里尝试做的事情。

但是我们所说的性能是什么意思呢? 性能有两个方面:吞吐量和延迟。

您可以将区块链性能可视化,例如流过管道的水。 交易就是水——你希望大量交易同时流过管道。 但是管道的长度决定了它的延迟——如果一个交易需要很长时间才能得到确认,即使很多交易可以一次得到确认,那也是不理想的。

延迟可以细分为区块时间(区块间隔的时间)和最终确定时间(区块肯定不会被回滚的时间)。 出块时间和完成时间很容易衡量。

但是要实际测量吞吐量,您需要一个标准的测量单位。 什么的吞吐量?

我们没有使用代币转移,而是查看了以太坊上最耗gas的产品之一:Uniswap V2,并将其变成了一个非常简单的基准。 如果你用 Uniswap V2 风格的交易填满了整个区块,每秒有多少笔交易可以清算?

我们选择这个基准是因为 1)它简单且易于测量,2)每个区块链都有一个 Uniswap V2 风格的 AMM 在生产中,3)它是常见的智能合约使用模式的典型。

对于大多数具有gas模型的区块链,这种粗略的练习应该很简单。首先,找到区块gas限制和出块时间,推导出链的gas/sec吞吐量;接下来,找到一个 Uniswap v2 风格的 AMM 并选择一笔 SwapETHforTokens 等效交易;最后,将第一个数字除以第二个数字,得出如果它的区块充满相同的 AMM 交易,它将达到多少 tx/sec。

注意:这不是一个完美的基准!它是特殊的,它不考虑可并行交易(因为 Uniswap 在同一个池上的交易必须是线性化的),并且它不能代表每种使用模式。但智能合约的使用始终是幂律分布的,并且最常用的 Dapps 往往是 AMM,因此在一组基准测试中,我们认为这有助于全面了解性能。

因此,事不宜迟,让我们顺着列表往下看。

Uniswap v2 每秒交易数量:平均 9.19,最大 18.38(由于 EIP-1559)

平均出块时间:13.2 秒(PoW,因此区块是在Poisson过程中随机挖掘的)

最终确定时间:66 秒(大约,ETH 区块不是真正的最终确定)

假设和方法:在 1500 万 gas 目标下,即以太坊与 EIP-1559 达到平衡时,以太坊每秒可以进行 9.19 次交易;在 3000万的 gas 限制下,它可以实现每秒 18.38 次交易(但如果保持在这里,费用会成倍增加)。我们将此swapExactETHForTokens 交易用作具有代表性的链上一跳交易。假设区块生产者可以用 Uniswap 交易完美地填充 1500 万gas 限制区块,每笔交易花费 123,658 gas,这意味着我们可以将 15M/123,658 = ~121.3 个交换放入一个区块中。如果我们假设区块每 13.2 秒到达一次,这意味着以太坊每秒处理 121.3/13.2s = ~9.19 Uniswap v2 swap。

我们将对列表中的其他 EVM 链使用类似的计算。

(注意:我们忽略了这种方法的Rollup,因为所有智能合约 L1 都能够添加Rollup。)

Ubeswap 每秒交易次数:平均 24.93,最大 49.86(由于 EIP-1559)

平均区块时间:5 秒

最终确定时间:5 秒(Celo 使用 PBFT 风格的协议,可立即完成区块)

假设:本次swap交易是代表交易、1000 万 gas 目标和 2000 万 gas 限制。

Quickswap每秒交易次数:平均 47.67,最大 95.33(由于 EIP-1559)

平均出块时间:2.5 秒

最终确定时间:Polygon 上有两种最终性概念

1.概率:这类似于大多数以太坊风格的区块链,其中规范链取决于完成的最多工作(最重链)。在 Polygon 的案例中,Bor 层(即区块生产者层)的最终确定性取决于难度较高的分叉。

2. 可证明:这类似于 Tendermint/IBFT,在规范链上的绝对多数签名。这通过检查点发生在 Heimdall 层(Polygon 的验证器管理和状态同步层)。这些检查点被提交给以太坊。

重组和分叉可以发生在 Bor 层,但不能发生在 Heimdall。检查点是 Bor 链状态的快照。一旦一个区块被包含在一个提交的检查点中,它就不能被重新组织(除非 >=1/3 的验证器集是不诚实的)。检查点大约每 25 分钟提交一次。

假设:此swap交易代表交易、1500 万 gas 目标和 3000 万 gas 限制。

Trader Joe 每秒交易:平均 31.65 次,但由于其弹性出块时间,在最大吞吐量下,Avalanche C 链可以处理足够的gas以达到每秒 175.68 次交易。但是,将吞吐量维持在该水平会导致费用成倍增加。

平均出块时间:平均 2 秒(Avalanche 是一种具有弹性出块时间的无领导者协议:只要支付足够的最低费用,就可以随时产生区块。Avalanche C 链曾有过在 1 秒内产生 >10 个区块的时期.)

最终确定时间:出块后约 1.75 秒

假设:此swap交易是代表交易,当前 800 万gas限制。

Avalanche 相对难以比较,因为它的区块生产机制与以太坊和 PoS 链如此不同。对于 Avalanche,它以最大吞吐量执行的操作与以平均吞吐量执行的操作之间存在很大差异。 (像以太坊这样已经实现 EIP-1559 的链的平均吞吐量是其平均吞吐量的 2 倍。)

PancakeSwap 每秒交易次数:194.60(币安智能链不使用 EIP-1559,所以这是一个固定数字)

平均区块时间:3 秒

最终确定时间:75 秒

假设:这个swap交易是代表交易,8000万 gas限制。

这结束了 EVM 区块链的基准测试——其虚拟机以以太坊为模型的区块链。 由于所有 EVM 链都使用相同的 gas 模型,我们可以将 gas/sec 视为吞吐量的基准。 实心条表示目标吞吐量,空心条表示限制。

EVM链的Gas/sec

您可以想象您以绝对极限运行 EVM,这种情况就是币安智能链(BSC)(现已更名为BNB Chain)发生的。 如果你想从智能合约中获得更高的性能,你将不得不完全远离 EVM。

Orca 每秒交易次数:273.34

区块时间:590 毫秒

最终确定时间:13 秒(Solana 也发出更快的“乐观确认”,但这些只能抵抗约 4.7% 的损坏。大多数 Dapp 都接受这个阈值。)

这是我们计算这个数字的方法。 这是一个笨的方法。

我们首先想为 Solana 找到一个等效的“gas limit”。 你在区块浏览器上找不到任何这样的数字。 我们首先询问了一些我们认识的 Solana 开发人员,但似乎没有人确切知道是否存在这样的限制。 于是我们卷起袖子踏上旅途,一探究竟。

我们首先了解到 Solana 确实有类似gas的东西,称为计算单位 (CU)。 从我们与验证者的对话来看,大多数人似乎认为 Solana 验证是“争分夺秒地在区块时间内打包尽可能多的交易”,但实际的限制是每个区块只能包含 4800 万个 CU。

其次,只有有限数量的 CU 可在单个区块中写入单个帐户。这个限制是为了防止过多的交易写入同一个账户,从而减少一个区块的并行性——尽管这正是在大规模拥塞期间发生的事情,例如在流行的 IDO 期间,当所有交易都在竞争使用单个合约时。

每个帐户的限制为 1200万。如果您遵循这个 1200万帐户 CU 限制、主网上 590 毫秒的区块时间以及每次 Orca swap的 74,408 CU 成本,我们得出的理论限制为 273.34 swap/秒。

这个数字似乎低于预期!为了让我们相信这个数字,我们希望通过经验验证这种方法。

为了确认我们正确地测量了它的性能,我们决定直接对 Solana 进行垃圾邮件攻击测试。出于显而易见的原因,我们不想向主网发送垃圾邮件,因此我们针对 Solana 开发网。请注意,Solana 的开发网运行在较小的集群上,因此比主网具有更快的出块时间(380 毫秒与主网的 590 毫秒),与主网相比,这将提高其性能。给定 380 毫秒的区块时间,我们应该期望开发网每秒清算 424.40 次swap。

我们在开发网上向 Orca SOL-ORCA 交易对发送垃圾邮件,以查看我们可以在单个区块中进行多少 Orca swap,然后推断为最大吞吐量。

在开发网区块高度106784857 中,我们设法实现了 184 次Orca swap

我们设法达到的最高数字是单个区块中的 184 次swap。假设区块时间为 380 毫秒,这给我们在开发网上实现 484.21 swap/秒。 (请注意,区块时间并不准确,因此这些数字存在一些偏差。如果您在我们获得最多交易的 3 个区块中取平均值,它看起来更像是每秒 381 次swap,这似乎更合理)。这似乎证实了我们的分析方法是正确的(约 10-15% 的增量),因此这意味着 Solana 的主网可能在 AMM 上执行大约 273 次swap/秒。

当然这只是一次测试运行,所以这是我们的代码 - 我们鼓励您使用它并与我们分享您的结果。

我们在这里掩盖了大量细节,如果没有我们在 Blockdaemon 的朋友的帮助,这一切都是不可能的。如果您想了解执行此操作所需的详细信息(以及更深入地了解 Solana 内部结构),请查看第 2 部分,我们将在其中介绍技术细节。

您可能会看到这一切并想知道:但我认为 Solana 通常能够执行 3000 TPS?

区块浏览器衡量 Solana 的 TPS 的方式可能会产生误导——它将内部共识消息视为交易,这是其他区块链所没有的。 Solana 大约 80% 的吞吐量是共识消息。减去这些,你剩下大约 600 TPS,其中大部分是非常便宜的 Serum 交易。只要接触到足够多的其他合约,Solana 也可以在生产中实现更高的性能。

AMM 测试:Uniswap v2 风格的 swaps/秒 性能

那么这一切的结果是什么?

首先,不要把这当成福音。自己算算。

其次,请记住,所有这些区块链都是移动目标。它们不断被优化,技术也在迅速发展,而任何基准都是即时快照。我们希望看到更多独立组织创建标准化基准,但这是我们最好的尝试。

第三,请注意,这些区块链之间的性能差异并不像宣传的那么大。以太坊和最好的链之间的性能差异大约是 10-25 倍,而不是 100 倍或 1000 倍。没有人能从线性化的 VM 事务中获得如此出色的性能。这将需要更多的工作和优化。

第四,如果你想要真正的高性能,你必须放弃 EVM。我们在这里只对 Solana 进行了基准测试,但还有其他非 EVM L1,例如 NEAR 和 Terra,它们也实现了更高的性能。但像 Solana 一样,他们无法从围绕 EVM 的工具和生态系统中受益。 (尽管 NEAR 拥有与 EVM 兼容的 Aurora 分片,并且其他 L1 正在尝试开发类似的虚拟化 EVM 实例。)

第五,用户现在对非以太坊 L1 的性能考虑并不那么敏感。 他们更关心生态系统的整体实力、良好的用户体验和低费用。 这些区块链目前没有在性能上进行竞争,因为它们实际上都没有被用于容量,除非在罕见的峰值期间,例如在 IDO 或市场崩溃期间。

我们预计所有主要 L1 的性能都会随着时间的推移而提高,因为开发团队会花费越来越多的时间来调整典型使用模式的性能。 毫不奇怪,在早期,这些区块链中的每一个都没有得到很好的优化!

但总的来说,我的印象是:以太坊是智能合约操作系统的 MS-DOS。 但是当前的区块链时代将我们带入了 Windows 95 时代。

MS-DOS(左)到 Windows 95(右)

下一代区块链代表了显着的进步,但要达到主流采用还有很长的路要走。

标签:SOLA区块链CATVICsolana币下半年怎么做区块链VICATEra Name Service

BNB热门资讯
金色观察 | 冲突爆发下的加密世界

自俄乌冲突以来,加密世界正经历多番行情震荡,并受到多方监管的注意。 数据显示,2月24日比特币价格下跌了10%,但其真实日交易量飙升至100亿美元以上,为自去年12月4日以来的最高点,投资者寻求避险的强烈抛售压力可能是比特币日成交量飙升的原因之一。(注:“真实交易量”指的是来自部分交易所的数据,这些交易所被认为信誉良好、没有清洗交易活动。

萌趣潮玩IP“ViViCat(薇薇猫)”3D盲盒数字藏品在鲸探平台限量开售

作为一部总播放量破4亿的动画片主角, ViViCat凭借圆滚滚的可爱形象, 以及对生活的独特认知, 正逐渐成为新的国潮顶流, 本次推出的ViViCat限量数字盲盒, 共有五套不同形象,代表五种生活态度, 总有一套戳中你的心。

调查:韩国虚拟资产服务提供商2021年净利润超过27亿美元

根据韩国主要金融监管机构相关部门的一项调查,韩国虚拟资产服务提供商(VASP)去年前三个季度从交易活动中获得了可观的净利润,总计超过 3.3 万亿韩元(约合 27.8 亿美元)。 3 月 2 日公布的这项调查是自去年根据修订后的《报告和使用特定金融交易信息法》要求 VASP 向韩国金融情报机构(KoFIU)注册以来的首次此类调查。

清华大学沈阳:元宇宙的大愿景

导  读 元宇宙这盘大棋,考验着我们的社会智慧和技术灵感,很值得从方方面面进行深入研究。 元宇宙大潮渐起,有四个问题需要我们思考。 元宇宙到底是什么,这是我们必须思考的第一个问题。稍微通俗一点而言,元宇宙是三维化的下一代互联网,其交互接口主要通过AR(增强现实)、VR(虚拟现实)、脑机接口等技术实现。

资本围猎虚拟人:腰缠万贯 无家可归

没有元宇宙,虚拟人无家可归。 “去年在拜年祭没看到洛天依有点伤心,结果在春晚上看到了。今年在拜年祭和春晚都没看到她,结果直接在冬奥登场。明年拜年祭再不带洛天依玩,她就要去联合国了。” 洛天依在北京冬奥会文化节开幕式的表演 在洛天依获得 440 万播放的北京冬奥会文化节开幕式表演视频的B站评论区,有粉丝写下了这段话。

Arthur Hayes认罪 加密杠杆之王兴衰史

2 月 25 日,据彭博社报道,BitMEX 两位联合创始人 Arthur Hayes 和 Benjamin Delo 已经于本周四在纽约法庭对违反美国银行保密法表示认罪,美国司法部将 BitMEX 定性为「平台」,鉴于他们的行为,Arthur Hayes 和 Benjamin Delo 被要求每人支付 1000 万美元的罚款。