复制成功

分享至

主页 > 数字货币 >

以太坊的最终性挑战:信标链是否仍然充满活力?

2023.05.30

原文作者:Yicheng

原文编译:深潮 TechFlow

介绍

“信标链有了生命。”在 2023 年 5 月 11 日和 12 日,以太坊面临了两次暂时的最终性丢失事件,测试了其韧性。尽管遇到这些挑战,网络仍然保持着活力,并自主地从这两个事件中恢复过来。我们即将深入探讨这些值得注意的事件,审查它们的影响以及随后实施的增强措施,以防止类似事件在未来发生。

以太坊的最终性挑战:信标链是否仍然充满活力?

事件概述

2023 年 5 月 11 日和 12 日将成为以太坊历史上具有重要意义的日子,因为在这两天,以太坊的韧性受到了严峻的考验。5 月 11 日,约在 20: 19 UTC 时,以太坊主网网络出现了区块产生速度的显著下降,导致最终确定延迟了四个纪元(epoch)——这是以太坊的第一次。第二天,发生了类似的事件,这次将延迟延长到九个纪元,并导致了不活跃惩罚。

在这些事件期间,观察到网络参与度出现了大幅下滑。第一次下滑发生在第 200, 551 个纪元,导致最终确定暂时停滞,直到第 200, 555 个纪元。第二次参与度下降出现在第 200, 750 个纪元,导致最终确定再次暂停,直至第 200, 759 个纪元。

尽管最初存在担忧,但以太坊网络通过自主恢复,展示了其内在的强大韧性。这些事件不仅证实了以太坊信标链的韧性,还突显了潜在改进领域。

以太坊的最终性挑战:信标链是否仍然充满活力?

不活跃泄漏(Inactivity Leak)

在非最终确定状态期间,以太坊网络部署了一个关键机制,称为“不活跃泄漏”。这一特性根植于以太坊 2.0 的 PoS 协议,旨在在重大干扰期间维持网络功能,如第三次世界大战或大规模自然灾害等事件,可能导致大量验证者离线,从而阻碍区块最终确定。

如果网络连续四个纪元(约 16 分钟)无法确定区块,将触发不活跃泄漏模式。在这种模式下,未对区块进行证明的验证者将开始失去部分质押的以太币(ETH)。这种惩罚随着时间的推移呈二次方增长,直到区块最终确定恢复。

这种模式具有双重威慑作用。首先,它取消了验证者证明的奖励。其次,它对不参与的验证者施加与其不活跃时间成比例的递增惩罚。这种机制激励验证者保持积极参与,加速网络恢复。这是在重大干扰期间维护网络完整性的基石特性。

影响

对网络参与者(验证者):

根据 Ben Edgington 提供的估计,假设在 8 个纪元的泄漏中有 65% 的验证者离线,不活跃泄漏导致大约 28 个 ETH 被销毁。这相当于每个离线验证者损失约 0.0006 个 ETH。

此外,在中断期间,证明奖励减少为零,导致额外损失了约 50 ETH,而这些 ETH 本可以通过其他方式发行。总的来说,验证者的估计总损失,包括不活动惩罚和丢失的证明奖励,约为 78 ETH。

对用户:

相反,最终用户受到的影响很小。尽管可用区块空间的减少导致交易处理能力降低,但 Gas 价格并未出现剧烈上涨,仍低于日内峰值。更重要的是,网络在这些事件期间始终保持活跃。

这意味着以太坊在没有任何重大中断的情况下继续处理交易,展示了其韧性。因此,用户可以在以太坊网络上基本不受干扰地维持操作,即使面临挑战,也突显了系统的强大韧性。

原因

Prysm 问题的核心在于缺少用于区块重放的缓存机制。这种缺失加剧了系统负载,产生了过多的 go 例程,并加大了 CPU 压力。在某些情况下,在上一个重放结束之前,新的重放就开始了,进一步加重了系统压力。

另一个加剧问题的因素是 Prysm 对来自先前纪元的证明错误处理 - 本应被忽略的数据却没有被忽略。这种低效率,加上对 head state 的次优使用,给系统带来了压力,尤其是在存款激增和验证者注册不断增长的情况下。

这些事件还揭示了不同以太坊客户端采用的策略之间的关键差异。当面临执行客户端问题时,Lighthouse 选择丢弃证明以维持网络活跃,而 Prysm 和 Teku 等则默认使用旧证明生成区块。

尽管面临挑战,但这些事件对于提供对软件效率低下、设计选择和网络状况的洞察力至关重要,使以太坊网络更加强大。这一系列事件并未导致任何永久性损害,反而增强了以太坊网络设计的韧性和多样性。

复苏

在这些事件中,以太坊信标链的韧性得到了真正的考验,并且表现得非常出色。以太坊信标链似乎蕴含生命,正在自我修复。

免责声明:数字资产交易涉及重大风险,本资料不应作为投资决策依据,亦不应被解释为从事投资交易的建议。请确保充分了解所涉及的风险并谨慎投资。OKEx学院仅提供信息参考,不构成任何投资建议,用户一切投资行为与本站无关。

加⼊OKEx全球社群

和全球数字资产投资者交流讨论

扫码加入OKEx社群

相关推荐

industry-frontier