ROLL:以太坊核心开发者会议:深入探讨以太坊合并及其路线演变_ROL

原文标题:《以太坊核心开发者会议更新 006》

这次更新与以往的有点不同。首先,我决定转移到 Mirror 发布更新。使用这个用于 1559 NFT 项目的平台是很不错的体验,而且我一直在找机会再次使用它。我会在 HackMD 保留更新列表,这样便于在一个地方轻松找到它们。

第二,由于我们现在的工作重点在合并 (The Merge) 上,本文其实不算是一篇「更新」,而是对走到当前架构选择的路线图演变的深入探讨。几周后,会有一篇类似的文章,详细介绍以太坊网络在合并后将如何运作。

合并将把以太坊目前的工作量证明 (PoW) 共识算法转为在信标链上运行的权益证明 (PoS) 机制。这个设计是「以太坊 2.0」路线图多次迭代的结果。让我们回顾一下过去几年路线图的变化吧。

阶段0,1,2

几年来,权益证明和分片的研发是彼此独立的。在 2018 年台北的一次研讨会上,大家决定将这两项研究计划统一起来,形成一个分三个阶段的「以太坊 2.0」路线图。Ben Edginton 在这篇文章里对当时的研讨会和总的理念作了非常好的总结。正是在这次活动中,Hsiao-Wei 展示了这张现在广为人知的「以太坊 2.0」简图:

来源:https://docs.google.com/presentation/d/1G5UZdEL71XAkU5B2v-TC3lmGaRIu2P6QSeF8m3wg6MU/edit#slide=id.g3c326bb661_0_298

以太坊发布主网合并准备清单:金色财经报道,据以太坊最新进度周报披露,主网合并准备清单已完成并在GitHub上正式发布,该清单文档概述了以太坊主网合并发布的准备工作,以及必须要完成的各种任务,主要包括规格(共识层、执行层、引擎API和面向公众的文件)、测试(单元测试、集成测试、压力测试和模糊测试)、测试网和研发工作,其中还包括了潜在的威胁分析,比如矿工攻击和合并后资源耗尽等问题。[2022/8/20 12:37:11]

这张图展示了当时新路线图的每个阶段将交付的内容:

阶段 0 将带来信标链

在阶段 1,会加入数据分片

在阶段 2,在每个分片加入虚拟机,以在系统里实现计算。

分片的数量最初定为 100,然后提高到 1024,最近又调低到 64。

随着信标链的工作在 2018 年开启,很明显,这个分三个阶段的以太坊 2.0 路线图将需要几年时间才能完全交付。伴随着使用以太坊人数的快速增长带来的成长阵痛,这带来了工作量证明区块链研究计划的复苏。在 2018 年的 Devcon IV 上,「Ethereum 1.x」这个术语被提出,用于涵盖这些研究计划。其中最重大的一项是无状态以太坊 (Stateless Ethereum),这个范式会把未被访问的状态从网络中移除,以限制状态的膨胀速度。

Aavegotchi将推出Polygon网络到以太坊的连接桥并计划上线Aave借贷平台:4月29日消息,Aave生态NFT游戏Aavegotchi发布V2路线图,团队计划于今年第二季度推出从Polygon网络到以太坊的连接桥,并且支持ERC-721协议(用于Aavegotchi和传送门)和ERC-1155协议(用于可穿戴设备、消耗品和抽奖券)。

另外团队还计划将GHST代币上线Aave借贷平台,与Pixelcraft工作室合作,为Gotchiverse设计一个新的NFT拍卖系统。[2021/4/29 21:11:16]

一方面有越来越多的关注放在让 PoW 链变得长期可持续上,另一方面开发者们意识到信标链可以比以太坊 2.0 路线图的其他部分更早实现,结合两者后出现了一个「提早合并」的提案。这份提案把现有的 EVM 链作为以太坊 2.0 系统的「分片 0 」来启动。这样不仅会加快搬到权益证明的速度,还会使应用层的过渡更顺滑,因为搬到权益证明不需要在应用层上做迁移。

这提案出来不久,Danny Ryan 在他的《Eth1+Eth2 客户端关系 (Eth1+Eth2 client relationship)》的文章里探索了 我们可以如何通过利用现有 Eth1 客户端实现提早合并。这将大大减少交付一个合并后系统和利用客户端的开发工作,因为 Eth1 客户端已经在主网上久经沙场了。按这条路走下去还可以给研究者更多时间解决阶段 1 和 2 的开放性问题 (请看这里),和无状态以太坊 (这仍然是非常活跃的研究领域)。

金色相对论 | Esther:以太坊2.0新路线图一定程度上对Staking起到助推作用:11月27日消息,在今日举行的金色相对论中,针对“对以太坊现在的“表现”有什么直观感受?此外对于新的“路线图”,是否支持?”的问题,ECN以太坊中文社区表示,与之前的路线图相比,主要有四个不同点:1) 阶段1简化为数据分片,将其作为rollup或是其他layer2方案的数据可用性层;2) 信标链将具备执行功能,当前以太坊主链能够直接合并到以太坊2.0链中,不再以分片形式并入; 3) 轻客户端、分片以及eth1和eth2的合并工作将并行推进,不再顺次实现; 4) 暂时搁置阶段2,但是保留分片执行的可能性。按照先前的路线图,用户要取出在以太坊2.0中质押的ETH,需要等到阶段2实现之后(至少2年),而新路线图的一个优势在于简化并且加速了eth1和eth2的合并过程,甚至有可能在分片之前就可以实现合并,大幅缩短了ETH的锁定时间。新路线图的另一个优势则在于能够在阶段1(数据分片)之后实现“分片+rollups”,提前为以太坊带来数千倍的吞吐量。以太坊2.0路线图的变动对目前即将启动的阶段0并没有太大的直接影响,但是根据前面的分析,新路线图可能在一定程度上对Staking起到了助推作用。[2020/11/27 22:20:40]

以 Rollup 为中心的路线图?

虎币矿池预计达到以太坊全网算力5%:据官方消息,虎币采用最新以太坊矿机(显卡5700 8卡8G),本次部署完毕后,新建的虎币矿池预计达到以太坊全网算力5%,排名前十,有望成为自有矿池最大的交易所之一。

HUBI是全球一站式数字资产交易平台,为用户提供诚信安全可靠的的数字资产交易服务。[2020/9/28]

很快到了 2020 年末:阶段 0 此时的进度已经达到 99%,信标链很快就要启动了。尽管在阶段 1 的工作进展顺利,但将在阶段 1 引入的分片上实现计算功能的阶段 2 仍然有很多未解决的问题:

如何从当前的 EVM 链顺滑过渡到分片的虚拟机?

从性能上看,有哪些替代虚拟机能被部署?

我们要如何确保各种虚拟机是真的安全?

如何协调所有虚拟机上的状态和余额?

......

同时,rollup (例如二层的扩容方案) 方面正发生非常快速的进展。多个团队公布要上测试网,且取得令人鼓舞的早期成果。

大约在这个时候,Vitalik 在 Ethereum Magicians 论坛上发表了长文,论述我们应该把短期和中期的扩容工作集中在 rollup 上。它们不仅会在阶段 2 完成前上主网,还会是阶段 1 的最大受益者。Rollup 会生成大量数据,而分片可以为它提供比 EVM 链消耗更低的存储。下面是文章的截图:

孙宇晨:“波场生态如今达成的成就是远超以太坊的”:据最新消息显示,波场TRON创始人兼BitTorrent CEO孙宇晨正在TokenClub进行直播,孙宇晨表示:“目前整个公链的格局变化非常快,波场团队一刻都不敢懈怠,波场虽然起步晚于以太坊,但整体来说,波场生态如今达成的成就是远超以太坊的。波场TRON4.0我们将领先于以太坊提前将零知识证明加入网络。波场还将实现诸多可能性,无论是波场的跨链协议,还是与三星的战略合作,与Poloniex为主的多家交易所的战略合作,都在不断夯实波场生态的未来。”[2020/6/24]

这种方法将对阶段 0-2 路线图产生几方面的影响。具体如下:

阶段 0 (信标链) 当时正处于部署主网前在测试网上运行的阶段,一旦 PoW 链准备好,信标链就可以成为共识层引擎,而不需要等到阶段 2 以后;

阶段 1 (数据分片) 的实现还需要几年时间,它从扩容的关键障碍变成一项增量改进,它会减少已经开发出来的扩容方案 (例如 rollup) 的开销;

阶段 2 (分片执行) 是有最多开放性研究问题且更复杂的功能,它可以在几年后推出,或完全取消,对扩容路线图没有任何影响。

研究社区快速就这个提案聚集起来,并在一个月内发表了一篇 ethresear.ch 文章,详细介绍了当前这个合并计划!

可执行信标链

当前的合并架构在首次于 2020 年 11 月由 Mikhail Kalinin 发表的《可执行信标链 (Executable Beacon Chain)》上得到详细说明。简言之,它结合了多次迭代的以太坊 2.0 路线图的洞见:

信标链已经启动了,现在可以作为共识引擎来使用;

Rollup 是扩展计算的最佳短期解决方案;

当前的 Eth1 客户端是作为合并后执行层的最佳基础;

搬到权益证明可以通过对当前运行的应用影响最小的方式实现

Mikhail 提议中的一个重大变更是,与其让当前的 EVM 链成为」分片 0」,不如直接与信标链连接。

这是一个简单但重要的见解——Eth1 执行层客户端已经是以共识算法可换的方式构建的。主网使用工作量证明,而测试网和私人以太坊网络使用的是权威证明 (proof of authority) 共识算法 (clique、IBFT 等)。

在文章里,Mikhail 提议直接把权益证明作为客户端使用的新共识算法。换句话说,就是把当前的工作量证明链与信标链合并。下面由 Trent Van Epps 制作的这张图很好地说明这个变化:

来源:https://twitter.com/trent_vanepps/status/1415741658067517441/photo/1

这种方法将最大程度地减少 PoW 链上客户端团队要做的工作,同时仍然带来「提前合并」和「以 Rollup 为中心路线」的所有好处 。

Rayonism 项目

为了验证可执行信标链架构的可行性,在名为 Rayonism 的长达一个月的黑客松里,客户端进行了原型设计。

在几周内,Eth1 和 Eth2 客户端的各种混合组合作为合并后的客户端在 EVM 上运行交易,通过信标链达成共识。

高度概括来说,现在的 Eth2 节点变成作为网络的共识层,而现在的 Eth1 节点则作为其执行层。共识层的功能扩展为把最新的链头信息发送给执行层,并向执行层请求区块。执行层仍然负责处理区块、广播交易、存储和管理状态,和处理 JSON RPC 请求。

这个实验验证了可执行信标链的架构是合理的,且可以用作过渡到权益证明的基础,现在这个过程被称为合并。

PoW -> PoS 的过渡?

Rayonsim 项目里没有测试的是从真正的 PoW 网络过渡到运行中的 Pos 网络。经过几次迭代后,现在已经大致敲定了一份规范。

为了实现从工作量证明到权益证明的过渡,在客户端里需要设置一个 TERMINAL TOTAL DIFFICULTY (终结总难度)。当发现区块上的难度超过了工作量证明链的难度时,客户端会进入过渡模式,它们会开始监听权益证明层的信息来达成共识。一旦共识层最终敲定的一个区块的难度超过了 TERMINAL TOTAL DIFFICULTY,执行层将完全停止监听和广播 PoW 区块信息。这样,合并就完成了!

对于应用,这不会对合约和用户造成任何影响。有一些操作码需要更新,但就仅此而已。对于信标链节点的运行者,在合并中需要选择一个执行引擎。同样地,如果你在工作量证明网络运行一个节点,在合并中需要选择一个共识客户端。随着合并工作的开展,你可以预期会有多个开发者测试网、教程和会议来讨论这些问题。

尽管合并的总体方案已经确定了,客户端团队还有一长串的事情需要在未来几个月内完成。大部分要做的事都可以在 这里 追踪到,值得关注的包括确定合并后的同步协议、为整个过程设置创建集成测试、上线开发者测试网并在不利条件下运行它们,以及为过渡期间的各种意外情况做计划。

如果你想深入了解实际的规范,EIP-3675 详细列出执行层客户端需要的变化,而共识规范中的 merge folder 详细列出了共识层的变化。

当事情稍微稳定下来,请期待另一篇深入以太坊客户端在合并后将如何工作的文章。谢谢你的阅读,下次再见!

感谢 Danny Ryan、Trent Van Epps 和 Mikhail Kalinin 对本文草稿的反馈。

一个值得注意的变更是「无状态以太坊」不再是过渡到权益证明的先决条件。

在过渡阶段根据总难度而不是区块或 slot 号可以更好处理重组情况。想了解更多,请参见 EIP-3675 里的 "Transition process (过渡过程)" 部分。

撰文:Tim Beiko翻译:ETH 中文站

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

大币网

[0:15ms0-3:340ms