撰文:Trent Van Epps,以太坊基金会成员
得以扩展改善以太坊网络的安全性和去中心化「集市」中的研究者和开发者们 在阅读下文之前,请记住本文并不是一个“官方”的路线图,只是对以太坊现状的有限且主观的看法。
01. 命名已经改变
时间线→ 进行中
让我们首先来谈谈我们在以太坊领域中的命名。虽然从这个方面开始似乎有些奇怪,但要知道的是,以太坊的命名框架是由其发展路线图来决定的。下面是最近流行的术语变化的两个例子,以及这种命名变化背后的原因。
执行 & 共识
无论出于何种目的,“Eth1”和“Eth2”这两个术语已经不再用于以太坊的核心开发中,可参见 Tim Beiko 撰写的《Great Renaming》文档:
这两个旧的命名方式表达了两个含义,即“Eth1在前,Eth2在后”和“Eth2诞生之后,Eth1就不复存在”。自 2020 年 10 月开始,以太坊核心研究者 Danny Ryan 就指出了这个问题。尽管 PoS 信标链自 2020 年 12 月初启动以来一直与当前的 PoW 以太坊主网并行运行,但使用 Eth1 和 Eth2 这两个术语会暗示当前的 PoW 以太坊在某种程度上已经消失了。实际上,当前以太坊主网上的链状态将会在合并发生之后无缝地与信标链结合。
不会有任何数据会被丢失,不需要进行任何迁移。
我们已经转向使用“执行”(Execution) 和“共识”(Consensus),而不再使用“Eth1”和“Eth2”这两个术语。我推荐你阅读 Dany Ryan 的这篇深入阐述的文章:
“执行”用户层的所有东西共识PoS 共识机制
在合并之后的环境中,执行层和共识层将一起共存。
“特性”,而非“阶段”
我们摒弃的另一个术语是“阶段”(Phases)。在过去,这是指一个特定的协议变更,比如“阶段0是指信标链”。
去年晚些时候,我们开始了非正式地、渐进地将“阶段”重构为“特性”(features)。首先,使用具体的“特性”来命名会更加灵活:当协议的设计更新或者范围扩大/缩小时,相比于直接使用该特性提案的名称来命名,使用“阶段X”的简写要更难以传达这些变更。
其次,“阶段”一词暗示了顺序性:“阶段X”之后必须是“阶段X+1”。这种命名方式行不通的一个很好的例子就是,当前正在进行中的合并数据分片
认知的灵活性
认知的灵活性「集市」中
我们之所以能够根据路线图来做出自适应的决策,是因为我们不拘泥于阶段或顺序。承认并内化我们没有完整的路线图是一种谦卑。这是以太坊哲学的重要组成部分,我很高兴看到它扎根于此。
02. 合并
时间线→ 5-8 个月
合并权益证明 (PoS)
合并给协议带来的好处
合并包含了对以太坊协议的许多重大改进:
- 当合并完成时,以太坊区块链将变得更加安全。区块将在某个时间点之后被“最终敲定”(finalized),同时将对重组区块链的验证者引入了罚没机制,也即抑制验证者对区块或者内部交易进行重组。
- 其次,PoS 消除了与 PoW 相关的大量能源消耗和硬件浪费。研究者们预计以太坊的能耗将在合并之后下降高达 99.95%。常规消费级硬件将取代目前运行以太坊共识的 ASICs 和 GPUs 硬件。这两大影响将为以太坊来带更加节能、更加多样化、地理上更加分散和抗脆弱的共识参与者。
- 第三,以太坊 PoS 将为实现分片 (sharding) 搭建平台,这也是一场重大的协议变化,将把以太坊区块链分成的许多并行运行的分片链。通过为数据可用性和结算增加可用的区块空间,分片将为 L2 扩容工作带来额外好处。
- 最后,合并将会减少 ETH 的年增发率,从当前的净 3.5% 到大约净 0%
通往合并的道路
Rayonism
最近,我们进行了 Amphora 互操作性工作坊,这个为期一周的活动继续在 一个对这场从 Pow 向 PoS 过渡进行建模的开发者测试网已经成功运行了!
Amphora: A Major Merge Milestone
从这次活动中获取的经验已经纳入到了最新版本的合并规范“Kintsugi”中。与此同时,还有一个称为 Pithos 的长期开发测试网。这种情况将在 2021 年 Q4 至 2022 年 Q1 期间重启多次,从而使用更新的规范来重新测试从 PoW 过渡到 PoS 的时刻。一旦这种过渡变得相当稳定,就可以对 Goerli 等现有的测试网进行升级以匹配合并规范。
The Merge Mainnet Readiness Checklist
03. 上海升级
时间线→ 10-12 个月
合并之后的以太坊的一个有趣的地方就是,虽然新旧两条链已经合并了,但客户端仍然是相互独立的:包括它们是如何架构的,以及致力于这些客户端的团队也是独立的。对于验证者来说,这意味着有大量的选择性:每个执行客户端都可以与每个共识客户端结合在一起,反之亦然。出于好玩,我罗列了这些客户端组合之后可能使用的新名称:
推特来源:https://twitter.com/trent_vanepps/status/1445008969756467203?s=20
如果需要,独立的执行层和共识层还允许进行非耦合的升级过程。这很好地符合了以太坊的“对关注点进行分离”(separation of concerns) 的哲学。换句话说,相比于“单片式区块链”,此时的以太坊对于一些更小的变更将更容易管理。
然而,上海升级将会以耦合的方式同时对共识层和执行层进行升级,从而使验证者的取款成为可能,也即允许验证者将他们的 ETH 从共识层取款至执行层,从而将二者更加紧密地绑定在一起。当 ETH 从信标链 (共识层) 撤回至执行层时,ETH 就能像我们在当前的以太坊链上一样使用了:可以将 ETH 作为价值存储,或者用于支付 NFTs,或者支付交易费等等。当前还有一些针对执行层的其他的提案正在被考虑是否纳入上海升级中,但这些提案尚未正式被接受。
在合并实际上线之前,我们将无法知晓这一可接受范围。
04. 以太坊研究
时间线→ 进行中
在上述工作正在被规范、实现和测试的同时,还有其他并行的研究工作正在推动以太坊向前发展。
数据分片
当以太坊转换为 PoS 之后,分片 (sharding) 可能是以太坊将会发生的最重要的变化。需要注意的是,当前的相关提案关注的是数据分片(data sharding),而不是分片执行。数据分片将为 L2s 网络提供更多可用于存储数据的区块空间,但这些分片还不支持像当前以太坊主网上我们所熟悉的本地用户交易执行功能。目前,Rollups 网络使用以太坊主网来进行此类结算操作。对于这种类型的分片的基础研究并不复杂,这意味着数据分片将可以更快地在主网上线并为 L2s 网络带来好处!
上图:原始示意图来自Hsiao-wei Wang,由 Quantstamp设计 这种优先考虑数据可用性,符合了在过去 18 个月里可扩展性研究和 dApps 领域的动态进展。Vitalik 在 2020 年 10 月发表的《以 Rollup 为中心的以太坊路线图》贴文很好地阐述了这一可能的未来。这是以太坊社区认知的灵活性的一个很好例子!
在未来某个时候,以太坊社区可能会决定增加分片执行功能。但
状态到期 & 弱无状态性
这一领域的研究将改革以太坊协议处理状态 (state) 的方式。状态是指所有的用户记录,包括合约、代币、NFTs 和地址。在当前的以太坊中,用户每次交易都会产生一笔一次性的成本,从而使该笔交易记录无限期地保存在以太坊状态中。从长远来看,这是不可持续的。
在过去几年中,一些有着不同权衡的提案已经被探索,包括诸如状态租金 (state rent) 和 ReGenesis 等。
其中一个主要的提案被称为“Weak Statelessness”(弱无状态性),该提案将变更以太坊节点存储和处理状态的方式:具体来说,只有区块提议者 (block proposers) 将被要求存储状态,而所有其他节点都无需存储状态即可验证区块。以下是这种方式将对不同参与者产生的影响:
- 用户:可以丢弃状态,但在提交交易时还需要提交一个“见证”(witness)。见证是指随交易一起发送的、用于证实交易有效性的证明 (proofs);
- 非验证者的节点:可以丢弃状态;
- 验证者/区块提议者:如果依赖于第三方来生产区块,则可以丢弃状态;
- 区块生产者:仍然需要存储所有状态。负责使用用户提交的见证 (witnesses) 来生产出包含有效状态变更的区块。
另一项提案成为“State Expiry”(状态到期)。根据此提案,如果状态在一段规定时间内没有被访问,那么该状态可以变为非活跃状态,或者从活跃状态变为“过期”。这可能是处于冷存储状态的 ETH,或者某个社区离开之后废弃的 ERC20s 代币等等。如果某个用户想要重新激活其状态,那么该用户发送的任何交易都需要附上一个见证 (weitness)。对以太坊活跃状态的大小进行限制的一大好处就是,节点在同步网络和继续维护时将变得更容易。
这两个概念都正在被积极研究、进行基准测试并通过概念证明 (PoC) 进行实现。想要更深入地了解目前的进展,可参考:
- Guillame Ballet 整理的附有链接的摘要:
- EthR&R Discord Guidebook 上的这些链接:
… 还有更多
我还要更多内容可以写的,比如 EVM (以太坊虚拟机) 的改进和增强共识机制的方法,但我将把这些内容留着下一篇文章中讲述。
如果你对研究上述这些重要的问题感兴趣,请在推特上直接发信息给我 () 来邀请你加入以太坊 R&D Discord 聊天频道。或者你可以前往 EthResearch 论坛进行深入了解:
0 条评论
请「登录」后评论