Galaxy硬核报告:七大案例看懂以太坊治理流程

2024-06-04 14:53:54 26183

作者:Christine Kim,Galaxy;编译:陶朱,金色财经

引言

谁管理以太坊?谁决定何时对以太坊协议进行哪些更改?以太坊协议的最终用户在影响以太坊核心开发人员的行动和决策方面有多大发言权?在本报告中,Christine Kim 通过全面概述决策过程中涉及的流程和机构,阐明了以太坊治理问题。她还讨论了以太坊历史上的关键事件,在这些事件中,开发人员和更广泛的以太坊社区之间的协调是迫切需要的,也是有争议的。

以太坊介绍

以太坊是全球最庞大的区块链,支持超过 4,000 个去中心化应用程序 (dapps),并吸引了超过 7,000 名开发者。随着 Arbitrum、Optimism 和 Polygon 等Layer 2扩展解决方案的采用和发展,该网络预计将进一步扩展。作为世界上第一个通用区块链,以太坊一直领先于其他Layer 1替代竞争对手,拥有所有通用区块链中最高的市值和网络安全(按总质押价值定义)。除了比特币,以太坊是加密生态系统中最重要和最有价值的区块链,这就是为什么对以太坊协议的更改以及进行更改的过程对加密行业的其他部分具有深远而重大的影响。

与比特币一样,以太坊的治理流程基于链下,由以太坊基金会牵头,并通过 Discord、GitHub、Ethereum Magicians 和 Zoom 等在线论坛进行。ETH 持有者不会通过链上提案或去中心化自治组织 (DAO) 投票做出任何决定。一方面,这确保了将代码更改推送到以太坊协议的治理流程不会受到大型 ETH 鲸鱼持有者的影响,也不会被恶意行为者利用治理相关智能合约中的漏洞利用。另一方面,链下治理形式难以审计和客观评估,因为流程故意不透明、主观和非结构化。

与比特币不同,以太坊非常擅长部署硬分叉,即向后不兼容的升级,需要数千名运行和操作以太坊软件的用户的协调。在过去 8 年的 19 次硬分叉过程中,核心开发人员已经调整了以太坊的治理流程,使其更加快速和流程驱动,严重依赖每周的电话会议系列,即所谓的“所有核心开发人员 (ACD) 电话会议”,来讨论和跟踪影响以太坊协议的治理决策。

t8WnYlyfAPCyDqy7xZDLK7HDqhzKyvGLgDDATyZC.jpeg

本报告深入探讨了以太坊治理,重点介绍了决策过程中涉及的流程、人员和论坛情况。然后,我们通过分析 DAO 硬分叉、Parity 多重签名漏洞、君士坦丁堡升级、ProgPoW、Afrigate、Merge 和上海升级事件,讨论了七个案例研究,以说明以太坊治理流程。

EIPP:以太坊改进提案流程

升级以太坊的官方流程称为以太坊改进提案 (EIP) 流程。它基于比特币改进提案 (BIP) 流程,这是向比特币协议提交代码更改的标准化流程。BIP 流程又受到 Python 的 PEP-0001 流程的启发,该流程概述了改进 Python 编码语言的治理模型。BIP 和 EIP 分别是描述比特币和以太坊的新功能或更改的文档。具体来说,EIP 是根据 EIP-1 定义的指南和模板进行格式化的。

EIP 有三种类型。

  • 标准追踪:大部分 EIP 都是标准追踪 EIP,它们指定对以太坊的代码更改需要硬分叉、影响以太坊的网络层或执行 API,或引入新的应用程序级标准和合约。标准追踪 EIP 进一步分为以下名称:核心、网络、接口和以太坊征求意见 (ERC)。

  • 核心:指需要全网升级才能激活的代码更改。

  • 网络:指以太坊对等网络层的改进,也称为“devp2p”。

  • 接口:指影响以太坊客户端 API 和 RPC 规范的代码更改。

  • ERC:指与以太坊应用层相关的改进。以太坊核心开发人员正在讨论将 ERC 与 EIP 分离为一个单独的治理流程。

  • 元/流程:元 EIP 不建议对以太坊的代码库进行更改,而是描述对流程(例如 EIP 的决策流程)的更改。

  • 信息性:信息性 EIP 也不建议对以太坊的代码库进行更改。它们提供有关以太坊的一般指导方针和信息,用户可以选择忽略或遵循。

任何对以太坊感兴趣的人都可以随时提出 EIP。EIP 提交到以太坊 EIP GitHub 仓库,然后由专门的 EIP 编辑人员审查 EIP 的技术合理性和格式是否正确。截至 2024 年 5 月,共有五位 EIP 编辑人员。这些编辑人员的姓名和 Github 用户名如下:

  • Alex Beregszaszi (@axic)

  • Gavin John (@Pandapip1)

  • Greg Colvin (@gcolvin)

  • Matt Garnett (@lightclient)

  • Sam Wilson (@SamWilsn)

这些人员由现任或名誉 EIP 编辑任命。新 EIP 编辑将以滚动方式考虑。上面列出的五位 EIP 编辑有权向符合 EIP 编辑标准的申请人授予新 EIP 编辑特权。成为 EIP 编辑的标准可以在 EIP 5069:EIP 编辑手册中找到。

作为 EIP 流程的一部分,在将 EIP 草案提交给 EIP 编辑之前,作者需要在 Fellowship of Ethereum Magicians 论坛上创建一个“讨论”主题,这是一个任何人都可以创建主题并讨论与以太坊和以太坊开发有关的问题的网站。除了 Ethereum Magicians 论坛之外,EIP 还可以发布在其他在线论坛上进行讨论,包括 Discord、ethresear.ch 和 GitHub。如果提议的 EIP 是核心 EIP,EIP 作者还将在 ACD 电话会议期间向以太坊客户端团队介绍他们的提案以供讨论。以太坊客户端团队是构建和维护以太坊客户端软件的实体。

五个主要的以太坊共识层 (CL) 客户端是 Prysm、Lighthouse、Teku、Nimbus 和 Lodestar。四个主要的执行层 (EL) 客户端是 Geth、Nethermind、Erigon 和 Besu。这九个团队的代表每周通过 Zoom 开会讨论 EIP 及其在以太坊升级中的实施。在每周一次的会议(即 ACD 电话会议)上提出 EIP 后,EIP 作者会继续收集反馈并审查其提案。EIP 作者可能会根据社区和客户团队的反馈修改其 EIP。经过此审查流程并获得客户团队支持的 EIP 将被考虑在未来的以太坊升级中实施。由于 EIP 数量众多,完成审查流程的提案并不能保证在下一次以太坊升级中实施。通常,以太坊客户端团队必须根据提案的相对紧迫性和范围,在几个技术上同样完善且随时可以实施的 EIP 之间进行选择,以纳入下一次升级。

gt4t7GG3gCEMzK0M0XPjUfnNAvMyLSVOX6orBiGK.jpeg

在过去八年中,以太坊上已最终确定并实施了 61 个核心 EIP,57 个核心 EIP 正在起草或审查中,143 个核心 EIP 已被撤回或被视为无效。根据这些数字,自链诞生以来,开发人员提出的核心 EIP 中有 23% 已在硬分叉升级中激活。

在本报告的下一部分中,我们将进一步详细讨论参与 EIP 流程的人员和论坛。

人员

有无数不同的团体参与以太坊的治理。作为世界上最去中心化的通用区块链,没有任何单个用户、个人或组织有权更改协议。然而,总的来说,以太坊生态系统中的每个用户和利益相关者都通过在社交媒体上分享对网络的看法、操作软件、贡献代码或只是与以太坊上的 dapp 交互,以大大小小的方式为治理做出贡献。由于以太坊背后没有一家公司,因此由不断发展和变化的生态系统参与者群体将用例应用于协议,引起人们对协议的兴趣,并最终赋予协议价值。

以太坊用户的集体意愿很少是同质的,而且如果不进行笼统的概括,就会变得太大而无法定义。本报告重点介绍了更广泛的以太坊社区中的四个特定利益相关者群体,本报告中将其称为大写“C”的“社区”。社区被定义为使用、构建或开发以太坊的个人和实体的无定形群体。在社区内,有以太坊基金会,这是以太坊的原始创始人为管理协议的增长和发展而设立的非营利组织。然后,我们将讨论以太坊客户端团队在社区中的作用。这些是构建以太坊软件的开发人员,可以说是 EIP 流程中最重要的决策者。然后,我们将定义验证器节点运营商,这是以太坊上一个相对较新的利益相关者群体,是代码更改的主要实施者;最后,我们将定义 dapp 开发人员,他们是以太坊的主要用户,他们塑造网络的用例并根据最终用户的需求向客户端团队提供反馈,说明优先进行哪些代码更改。

以太坊基金会

以太坊基金会 (EF) 是最早也是最著名的专注于以太坊的非营利组织。它由以太坊的原始创始人创建,包括 Vitalik Buterin、Gavin Wood、Joseph Lubin 等。在创世时,EF 从创世区块预挖中获得了最大的 ETH 供应量,在总 7200 万 ETH 分配中占 1200 万。

WpIcJ1dYikzdNlOSS3mo46NPe0XJfPaVVoUneMMU.jpeg

然而,自 2015 年以来,在几个市场周期中,基金会持有的 ETH 总数量一直在减少,估计截至 2022 年 4 月,其持有量不到 ETH 总供应量的 0.3%。与以太坊一样,管理 EF 的结构和流程很难定义。与传统的非营利组织不同,以太坊基金会没有明确的组织结构或角色。正如基金会网站所述,EF 的角色“随着以太坊生态系统的发展而演变和改变其形态”。更具体地说,多年来,随着社区利益相关者数量的增加,EF 在社区中的突出地位逐渐减弱,削弱了 EF 对更多生态系统参与者的集中影响力。

截至 2024 年 5 月,EF 继续在社区中雇用几名以太坊协议研究人员和开发人员,并领导围绕 ACD 呼叫的组织,以及一年一度的以太坊开发者大会 Devcon。该组织在员工人数方面的规模未知。基金会网站上公开列出的成员只有:Aya Miyaguchi(执行董事)、Vitalik Buterin(以太坊联合创始人)和 Patrick Storchenegger(董事会成员)。基金会关于其运营和财务的最新报告于 2022 年 4 月发布。

客户团队

客户端团队构建并维护运行和连接以太坊网络所需的软件。以太坊有九个主要客户端团队,其中只有一个由以太坊基金会直接维护。以下是每个以太坊客户端团队的背景:

9IisDmxBvAYL7Pj1QVf9HnnEw3KPYhgiiRBNvbUE.jpeg

1. Geth (EL):最古老、最受欢迎的以太坊软件客户端,简称 Go Ethereum 或 Geth,由以太坊基金会独家资助。Geth 用 Golang 编写,被认为是最久经考验的以太坊客户端。代码由 10 名开发人员组成的团队维护,并根据 GNU 宽通用公共许可证 (LGPL-3.0) 开源。LGPL-3.0 许可证是一种版权开放源代码许可证,要求用户对原始代码存储库所做的任何更改都开源代码。

(顺便说一句,LGPL-3.0 和 Apache 2.0 许可之间的主要区别在于衍生作品。根据 Apache 2.0 许可,代码可以不受限制地分叉和分发,而根据 LGPL-3.0 许可的代码衍生作品必须保持自由和开源。此外,根据 Apache 2.0 许可的软件可以与根据其他类型许可的软件结合使用,而 LGPL-3.0 许可的软件只能与其他 GPL 许可的软件兼容。通常,Apache 许可证 2.0 是一种更宽松的许可,而 LGPL 限制使用以专门鼓励开源开发。)

2. Nethermind (EL):Nethermind 成立于 2017 年,是以太坊第二受欢迎的 EL 客户端,用 C# 编写,并基于名为 .NET Core 的开源计算机软件框架。Nethermind 背后的团队是自力更生的,最初由以太坊基金会资助。多年来,该团队还通过 Gitcoin 从以太坊社区 [JA1] 以及独立贡献者和合作伙伴那里获得了资金。2021 年 7 月,Nethermind 宣布与Layer 2扩展项目 Starkware 建立战略合作伙伴关系。Nethermind 团队由来自 55 个国家的大约 220 名成员组成。Nethermind 客户端在与 Geth 相同的许可证(GNU 宽通用公共许可证)下开源。

3. Erigon (EL):Erigon 以前称为 TurboGeth,是 Geth 客户端的一个分支,经过重新设计,可提高同步速度和磁盘空间效率。它成立于 2017 年,并于 2020 年 7 月完成了 alpha 版本。Erigon 团队由 10 名开发人员组成,已获得以太坊基金会和 BNB Chain 等多家贡献者的资助。值得注意的是,该团队支持其他区块链和侧链的客户端软件,包括 BNB Smart Chain 和 Polygon。此外,该团队过去还维护过一个用 Rust 编写的以太坊客户端 Akula 和一个用 C++ 编写的客户端 Silkworm。该团队最近宣布创建一个名为 Caplin 的新以太坊 CL 客户端。Erigon 客户端在与 Geth 和 Nethermind 相同的许可下开源。

4. Besu (EL):Besu 以前称为 Pantheon,是一款专为企业和机构使用的以太坊客户端。该项目由以太坊创业工作室 Consensys 于 2018 年 11 月启动,2019 年更名并移至 Hyperledger 基金会拥有的新 GitHub 存储库。(Consensys 是 Hyperledger 基金会的成员。)Consensys 内部负责构建和维护客户端的开发团队称为 Consensys Quorum,以前称为 Pegasys。Besu 用 Java 编写,并根据 Apache 2.0 许可开源。Consensys 还资助以太坊 CL 客户端 Teku 的开发。截至 2020 年 10 月,Pegasys 团队(也称为协议工程团队)拥有 70 多名成员。2023 年 1 月,Consensys 宣布将其员工人数从 900 人减少到约 800 人,减少 11%。

5. Reth (EL):Reth 是 Rust Ethereum 的缩写,是 Ethereum EL 的实验性全节点实现,旨在供广泛的用户使用,包括 MEV 搜索者、桥接器、Layer 2和 RPC 节点运营商。Reth 客户端由加密风险投资公司 Paradigm 维护,用 Rust 编写,并根据 Apache 2.0 许可开源。Paradigm 资助了一个由 8 名开发人员组成的核心团队来构建 Rust。然而,开源代码库拥有超过 90 名贡献者。2024 年 3 月,Rust 团队发布了 Reth v0.2.0,这是客户端 Beta 发布周期中的第一个主要版本。

3Ig3pLDpTW94Oqj4hp45TpjkFdLoodPNUBxM6coh.jpeg

6. Prysm (CL):Prysm 是最受欢迎的以太坊 CL 客户端,用 Golang 编写,并在与 Geth、Nethermind 和 Erigon 相同的许可下开源。它由 Prysmatic Labs 维护和开发,Prysmatic Labs 是一家区块链基础设施公司,成立于 2018 年,最初由以太坊基金会、Gitcoin、Aragon、Spankchain 等机构资助。2022 年 10 月,该公司被 Offchain Labs 收购,后者是以太坊Layer 2扩展项目 Arbitrum 背后的公司。Prysmatic Labs 雇佣了大约 12 名员工。

7. Lighthouse (CL):Lighthouse 是第二受欢迎的以太坊 CL 客户端,用 Rust 编写,并在与 Besu、Apache 2.0 相同的许可下获得许可。该客户端由 Sigma Prime 维护和开发,Sigma Prime 是一家位于澳大利亚悉尼的信息安全和软件工程公司。Sigma Prime 因其在 Lighthouse 客户端上的工作而获得了以太坊基金会、Consensys、Gitcoin 和其他机构的资助。该公司成立于 2018 年,拥有约 25 名员工。

8. Teku (CL):Teku 由 Besu (EL) 背后的同一支团队维护,是 Consensys 以机构为中心的 CL 客户端,用 Java 编写,并在与 Besu 和 Lighthouse 相同的许可下开源。Teku 以前称为 Artemis,于 2020 年推出,与 Besu 一样,由 Pegasys 团队构建和维护。

9. Nimbus (CL):Nimbus 用 Nim 编写,并在与 Besu、Teku 和 Lighthouse 相同的情况下获得许可,旨在提高资源效率,使节点运营商可以轻松地在资源受限的设备(例如手机和笔记本电脑)上运行以太坊客户端软件。Nimbus 团队由 10 名员工组成,几乎完全由 Status(加密钱包和 Web3 浏览器)和以太坊基金会资助。Nimbus 团队还构建和维护一个 EL 客户端,也称为 Nimbus。该团队成立于 2018 年。

10. Lodestar (CL):Lodestar 用 Typescript 编写,并根据 GNU 宽通用公共许可 v3.0 获得许可,是一款专注于轻客户端功能的以太坊客户端。轻客户端是一种节点,即运行以太坊软件并连接到以太坊区块链的计算机,可以轻松同步到链,而无需从创世下载完整的链历史记录。启动轻客户端的带宽和处理负载明显小于完整节点。Lodestar 由总部位于加拿大多伦多的区块链研发公司 ChainSafe 开发和维护。该项目最初由以太坊创始人 Vitalik Buterin 于 2018 年资助。ChainSafe 此后通过以太坊基金会和 Gitcoin 等组织获得了资助。ChainSafe 拥有 100 多名员工。

为以太坊客户端软件做出贡献的个人通常被称为以太坊“核心开发人员”。然而,这个术语也被用来描述专注于升级测试或一般协议研究工作而不是客户端开发的基金会员工和承包商。一般来说,任何积极为推进以太坊核心协议领域做出贡献的个人,无论是通过研究、客户端开发还是升级测试,都被称为以太坊核心开发人员。核心开发人员这个术语是社区中一个热议话题,因为没有任何个人或实体有权力定义这个术语或阻止社区中的任何人自由使用它。

验证者节点运营商

通过新铸造的 ETH 奖励的唯一类型的节点运营商是验证者节点运营商。自合并以来,验证者取代矿工成为网络的主要区块生产者。当在以太坊上质押 32 ETH 时,就会创建验证者。一旦激活,验证者将被随机分配职责,例如验证交易和将新区块附加到区块链。作为履行这些职责的交换,验证者通过网络发行、交易费和最大可提取价值 (MEV) 获得奖励。验证者在以太坊上存入的质押总额是网络安全的功能,可确保除非恶意行为者控制超过 33% 的总质押 ETH,否则不会发生对网络的攻击。

AKrp9SrE8tiva8Aaohf0Slnp1rSDyN9LK5dAJbY1.jpeg

节点运营商是一群个人和实体,他们有权实施或拒绝客户端团队对以太坊软件所做的代码更改。作为背景,当客户端团队对软件进行向后兼容的代码更改时,升级称为“软分叉”。相反,当向客户端软件推送向后不兼容的更改时,就会发生“软分叉”。所有节点运营商都必须在某个区块高度之前升级其软件,以避免在硬分叉激活期间被踢出网络。在硬分叉期间故意不升级其软件或运行替代的向后不兼容软件的节点运营商将造成永久性的链分裂。仅在以太坊的一个版本上运行的验证者将因在另一个竞争版本上不活跃而受到惩罚。通过逐步增加惩罚,每个以太坊版本上的活跃验证者的质押 ETH 余额最终足以推动网络向前发展。

XrTdoAHVF8GPMOei7tDQrG9Qhx8RYjZRhcBIWX7N.jpeg

理论上,节点运营商对于在以太坊上实施哪些代码更改以及拒绝哪些代码更改拥有最终决定权。然而,在实践中,由于一些原因,由于验证器节点运营商之间的分歧而导致以太坊发生永久性链分裂的可能性不大。

  • 以太坊一直有一个雄心勃勃的发展路线图,从发布之初就设想对共识协议、费用动态和用户体验进行重大改变。不断变化的代码库的预期为验证器节点运营商树立了先例,使他们能够规范频繁的升级,而不是拒绝升级。

  • 去中心化金融 (DeFi) 生态系统(包括预言机和稳定币)以及L2 生态系统的增长增加了分叉以太坊的成本,因为永久性的链分裂会分散链上流动性,并迫使无法重复操作的多个 dapp 和 L2 选择一个网络而不是另一个网络。

  • 以太坊上质押的大多数 ETH 都是通过代表用户运营验证器软件的服务提供商质押的。这意味着大多数在以太坊上获得奖励的用户和实体并不直接控制节点或代表他们对节点进行的软件升级。质押者与实施以太坊客户端团队准备的代码更改有一定距离,因此,与质押服务相比,有时可能没有那么积极地跟踪或积极参与协议开发的决策。

QDWnL5AasJtPPLiPqrStFMaePzhDptwlSH4RvAN3.jpeg

尽管存在这些原因,但在以太坊的历史上,以太坊验证者节点运营商曾强烈影响过协议升级的决策。例如,在以太坊过渡到权益证明后的第一次升级中,质押以太坊用户的利益是影响质押 ETH 提款优先级的主要因素。此外,在验证者成为以太坊的主要节点运营商之前,当节点主要由矿工操作时,尽管以太坊存在一个非常雄心勃勃的发展路线图,并且必然需要频繁升级才能实现,但以太坊还是经历了永久性的链分裂。这次链分裂产生了以太坊经典,这是以太坊历史上第一次也是迄今为止唯一一次重大链分裂,发生在 2016 年以太坊早期,当时 DeFi 或 L2 行业尚未发展。

验证者节点运营商是以太坊上一个重要的利益相关者群体,负责执行客户端团队准备的硬分叉升级。他们在治理过程中作为代码执行者的角色是微妙的,这种角色受到最近升级的影响,例如合并和上海(将在本报告后面详细讨论),以及矿工的遗产,即以太坊的前主要节点运营商,自以太坊诞生到 2022 年底的大部分历史中执行了升级。

Dapp 开发者

除了 EF、客户端团队和验证器节点运营商之外,以太坊的 dapp 层是影响代码更改和硬分叉升级的下一个最重要和最有发言权的焦点小组。dapp 开发人员是以太坊的主要用户,他们与以太坊代码库交互以部署智能合约代码。大多数最终用户通过由钱包服务、基础设施提供商、交易所或 dapp 开发人员自己支持的前端用户界面 (UI) 与 dapp 交互,而不是直接通过以太坊区块链。正因为如此,dapp 开发人员的需求有时是推动以太坊开发的核心,也是某些代码更改优先于其他代码更改的核心。

例如,在坎昆升级中加入 EIP 1153 主要是由两个 dapp 协议团队 Uniswap Labs 和 Optimism Labs 的努力推动的。EIP 1153 引入了新的经济高效的智能合约操作 TSTORE 和 TLOAD,用于将数据存储在执行后从以太坊链状态中丢弃的交易中。在讨论代码更改的 ACD 电话会议上,OP Labs 的联合创始人 Mark Tyneway 强调,仅在 Uniswap 上,EIP 就有可能为最终用户节省 300 万美元/年的 gas 成本。EIP 1153 最初于 2018 年 6 月提出,后来提议纳入 2022 年 11 月的上海升级。EIP 于 2024 年 3 月 13 日作为坎昆升级的一部分在主网上激活。

除了 EIP 1153 之外,最近几个月,dapp 开发人员还主要带头提出了与账户抽象相关的 EIP。账户抽象是一项功能,它允许智能合约对启动交易进行可定制和可编程的授权。在以太坊上,只有外部操作账户 (EOA) 可以发送和接收加密货币。与智能合约不同,EOA 不能执行代码。启用帐户抽象一直是以太坊核心开发人员和 dapp 开发人员的长期目标,最近通过向后兼容的 EIP(称为 ERC 4337)获得了关注。该提案最初由以太坊创始人 Vitalik Buterin 于 2021 年 9 月提出,目前仍处于草案阶段,但正在由各种客户端团队、EF 研究人员和 dapp 开发团队(如 Matter Labs、Polygon、Gelato 等)积极迭代。

很难量化 dapp 开发者社区对客户端团队的影响,尤其是当开发者的影响也会影响社区情绪时。除了 dapp 开发者之外,最终用户以及 ETH 持有者、交易所和其他区块链基础设施提供商都在代码更改倡导中发挥一定作用,尽管程度较小。正如我们在本报告中进一步讨论的那样,客户端团队并不能免受最终用户通过 Twitter 和其他社交媒体论坛发出的信号的影响。此外,组成客户端团队的个人也可能运营自己的验证器节点,并拥有构建不同类型的 dapp 和链上服务的附带项目。因此,虽然每个焦点小组(即客户端团队、验证器节点运营商和 dapp 开发人员)的利益各不相同,但组成这些小组的个人往往重叠,使得参与以太坊治理过程的利益相关者难以整齐地分类或定义。

论坛

以太坊生态系统利益相关者群体的声音汇聚在一系列不同的论坛上。一些论坛专门用于从客户团队中达成共识,而不是从整个以太坊生态系统的利益相关者中汇总共识。这些论坛使用的主要语言是英语。这可能是因为一般来说,英语被认为是世界上最全球化的语言,使用人数最多。对于希望参与以太坊治理过程的个人和公司来说,英语是一项关键要求。然而,EF 正在努力通过将有关以太坊的信息文件翻译成几种不同的语言,改善通过治理做出的关键决策与非英语社区的沟通。由 EF 运营的 ethereum.org 网站已被翻译成 55 种语言。此外,EF 特意将 Devcon 设在世界各地,以扩大以太坊对非英语人口的影响力。2022 年,Devcon VI 在哥伦比亚波哥大举办。

以下是讨论、组织和执行以太坊开发的四个主要论坛的列表。除了这些论坛之外,围绕以太坊的社区讨论也在 Twitter 和 Reddit 等社交媒体平台上分享。然而,社交媒体平台虽然很受欢迎,但并不经常举办有关以太坊开发或治理的集中深入讨论。相反,以太坊社区成员使用它们来分享有关以太坊相关主题的快速更新和信息,这些主题可以引发讨论,但并未被正式认可为 EIP 决策过程中的关键治理论坛。

以太坊全核心开发者 (ACD)

关于以太坊协议开发的最重要的决策论坛之一是 ACD 电话会议。ACD 电话会议由以太坊基金会组织,早在 2015 年 11 月就开始了,即以太坊推出几个月后。它们是公开录制的 Zoom 电话会议,持续大约一个半小时。它对以太坊社区中的任何人都开放,但最常参加的是 EIP 作者、客户团队、以太坊基金会研究人员和以太坊 Cat Herders。ACD 电话会议对任何感兴趣的人开放,可以通过直播或直接在 Zoom 上加入。

从 2016 年到 2021 年,ACD 电话会议由以太坊基金会员工 Hudson Jameson 主持。在此期间,ACD 电话会议每两周举行一次。Jameson 此后不再担任 ACD 电话会议主席,目前担任各种以太坊项目的顾问,包括 Status、Chainlink 和 Polygon 背后的开发团队 Matic Labs。从 2021 年开始,以太坊基金会的 Tim Beiko 接任 ACD 电话会议主席。与此同时,从 2018 年到 2022 年,专注于构建以太坊权益证明共识协议的以太坊核心开发人员也组织了每两周一次的电话会议。这些电话会议由以太坊基金会的 Danny Ryan 主持。

自 2022 年 9 月合并启动以来,ACD 电话会议已更名并正式化为两个独立的会议系列:所有核心开发人员执行 (ACDE) 和所有核心开发人员共识 (ACDC) 电话会议。每次电话会议每两周举行一次,这意味着现在每周都会举办一次 ACD 电话会议。ACDE 电话会议由 Tim Beiko 主持,重点关注以太坊执行层 (EL) 的协议级更改。ACDC 电话会议由 Danny Ryan 主持,重点关注以太坊共识层 (CL) 的协议级更改。

合并后的 ACD 电话会议结构反映了以太坊的双网络性质以及围绕更改协议而增加的协议复杂性,因为它涉及越来越多的主题专家和特定于网络的客户团队。 ACD 通话主要讨论 EIP 的技术优点。尽管这是目标,但有时很难避免围绕 ACD 通话决策的道德或伦理进行讨论,具体取决于手头上的事情。自 2015 年以来,已经组织了 250 多次 ACD 通话。大多数都进行了现场录制,可以在 YouTube 上重看。

ETHMagicians 和 Ethresear.ch

ACD 电话会议的议程通常受到 ETH Magicians 和 Ethresear.ch 论坛上发布的讨论和对话的影响。这些论坛是讨论处于构思或草案阶段的 EIP 并传阅以征求反馈的地方。此外,这些论坛还围绕以太坊协议的非技术问题进行深入讨论,例如根据社区情绪,哪些 EIP 和计划应优先升级。虽然两个论坛都同样活跃,但 ETHMagicians 是一个比 Ethresear.ch 更通用的论坛,几乎可以讨论任何有关以太坊的技术或非技术主题。Ethresear.ch 倾向于展示关于协议技术代码更改的早期研究想法,一旦正式化,就会发布到 ETHMagicians 上进行更广泛的社区讨论。

64bMcLwenhNzS9SK9i47RkXMhvYBxkuMMICuIz95.jpeg

ETHMagicians 由前以太坊基金会核心开发人员 Jamie Pitts 和 Geth (EL) 客户端“Lightclient”的匿名开发人员组织。Ethresear.ch 由多位以太坊基金会员工组织,其中包括 Hsiao-Wei Wang、Justin Drake、Danny Ryan 和 Vitalik Buterin。

异议

对于为即将进行的升级和向客户端团队提供紧急更新而准备的活跃 EIP 的日常协调,有一个专门的 Discord 聊天室,以太坊核心开发人员、研究人员和以太坊社区的其他成员可以在此实时协调开发。以太坊研究与开发 Discord 频道是鼓励客户端团队和更广泛的以太坊社区共同解决协议问题、开展研究计划和提出问题的地方。在以太坊升级期间,客户端团队将其用作主要沟通渠道,以传达以太坊网络的健康状况并协调以太坊测试网络上升级的启动。它也是一个交流和组织社区电话的论坛,这些电话与 ACD 电话同时进行,例如讨论 EIP 4844、proto-danksharding 和 EIP 流程更改的技术细节的电话。

从 2015 年到 2018 年,询问有关以太坊协议的问题和参与协议日常开发的主要渠道是通过一个名为 Gitter 的聊天室。然而,随着以太坊社区和协议贡献者数量的增长,需要一种更复杂的方法来在一个论坛上组织多个聊天室。因此,开发人员将通信迁移到一个共享的 Discord 频道,截至 2023 年 7 月,该频道为以太坊研究和开发的各种细分主题提供 50 多个独立聊天室。以太坊研究和 Discord 频道是异步讨论 ACD 主题的中心,也是跟踪在 ETHMagicians 或 Ethresear.ch 上提出的提案实施的积极工作的中心。

GitHub

最后,用于起草和记录以太坊代码库状态的主要论坛是 GitHub。在 GitHub 上,名为“以太坊”的组织页面托管了数百个代码存储库。这些存储库包含以太坊研究人员和客户端团队正在为即将到来的升级而开发的协议草案版本的代码,以及 ACD 调用的历史记录和最终 EIP 提案的副本。该存储库托管的规范不仅详细说明了以太坊的核心协议,还包括有关节点 API、Solidity 智能合约语言、测试工具等的文档。

wQesf84qLh5xXf6yF37dGfj6MWjm6no5FF8gXT6Z.jpeg

图片说明:以太坊官方 GitHub 首页。来源:GitHub

以太坊核心代码库(定义为 EL 和 CL 规范)每月都会发生变化。以太坊基金会的客户团队和员工是有权合并和更新以太坊 GitHub 存储库的主要个人。当在 ACD 呼叫或 Discord 上异步做出关键决策时,对以太坊规范的实际更改(即影响以太坊代码的治理决策的执行)发生在 GitHub 上。在 GitHub 上,用户可以跟踪对以太坊规范所做的更改并访问最新版本的规范。将代码更改合并到官方以太坊 GitHub 存储库是最重要的步骤之一,标志着在其他治理论坛上做出的决策的最终确定和实施。

虽然 GitHub 是更广泛的计算机程序员中领先的开源代码开发平台,但以太坊开发人员过去曾讨论过减少对这个中心化平台的依赖的必要性,特别是考虑到 GitHub 因政府压力而关闭了对其平台的访问。开发人员将来可以探索的用于去中心化开发的 Gitcoin 替代方案包括 Radicle 和 Mango。此外,鉴于 GitHub 所依赖的版本控制系统 git 是一种无需通过网站托管或管理的无权限协议,因此鼓励社区在其设备上托管以太坊代码库的本地副本。此外,在 ETHMagicians 和 Ethresear.ch 上主持有关代码更改的对话的动机之一是将 GitHub 上的问题解释和拉取请求复制到其他几个平台上。

荣誉标签

除了上面提到的主要人物和论坛之外,还有一些组织和协议多年来对以太坊的发展产生了有意义的影响。

The Ethereum Cat Herders

Ethereum Cat Herders 是一个由捐款资助的个人团体,负责创建会议记录、撰写信息博客文章、开展社区宣传以及制作视频内容,以向广大公众普及以太坊知识。该团体由著名的以太坊社区领袖于 2019 年 1 月创立,例如前 ACD 主席 Hudson Jameson 和前核心开发人员 Lane Rettig。该团体由 Herder-in-Chief Pooja Ranjan 领导,他是区块链发布网站 EtherWorld 的创始人。Cat Herders 是一个由以太坊“项目经理”组成的去中心化团体,旨在帮助协调网络升级并改善客户团队与更广泛社区之间的沟通。他们对 EIP 活动进行调查和分析,并告知如何改进围绕以太坊代码更改的治理流程。

除了参与通过项目管理引导 EIP 流程外,他们每周还会主持 EIP 改进电话会议和 EIP 办公时间,以跟踪每个 EIP 的状态并引导它们经历讨论、起草、审查、最后一次通话和最终阶段。他们还每周举办一次 YouTube 系列活动,介绍 EIP 作者及其提议的代码更改,名为 PEEPanEIP。Ethereum Cat Herders 与 EIP 编辑者密切合作,以完善 EIP 流程并根据小组共识进行更改。

以太坊协议公会

除了以太坊基金会和以太坊 Cat Herders,还有以太坊协议公会,这是一个智能合约应用程序,旨在帮助资助以太坊核心开发。任何人都可以将可替代代币发送到智能合约,然后将其分发到积极为以太坊协议研究或客户端开发做出贡献的个人所拥有的地址注册表中。截至 2023 年 6 月,协议公会注册表上有 142 名个人,来自各种客户团队,包括 Geth、Erigon、Besu、Lighthouse、Lodestar、Nethermind、Prysmatic Labs、Teku 和 Status。截至 2024 年 5 月,协议公会已分发超过 1780 万美元,资金由 Uniswap、以太坊名称服务、Ether.fi、Nouns DAO 和 Moloch DAO 等主要 dapp 项目积极捐赠。

协议公会随时接受来自任何地址的资金。所有资金都会随着时间的推移归属注册表,并根据每个成员积极为以太坊协议做出贡献的时间按比例分配给成员。协议公会可以作为评估以太坊核心开发人员数量随时间增长的代理。

EADiXcXLi98XvsoJMiaLuywh1rZ0Dy19A8gl6Bv9.jpeg

协议公会致力于通过自愿捐款积极资助所有以太坊核心开发者,这些捐款会自动分发给贡献者(也称为公会成员)。公会成员自己负责通过删除或添加新成员来保持开发者注册表的更新。

Optimism的追溯性公共物品资助

协议公会的杰出贡献者是 Optimism Collective。Optimism 是以太坊上第二有价值的 L2,仅次于 Arbitrum,链上资产价值高达 65 亿美元。Optimism 由一个名为 OP Labs 的开发团队于 2021 年推出。OP Labs 运营负责在称为序列器的区块中聚合和排序用户交易的软件。虽然目的是随着时间的推移将此功能去中心化,但 OP Labs 已承诺将其序列器通过交易费获得的所有利润用于资助公共产品实验。所有序列器收入都归 Optimism 基金会所有,该基金会是一个致力于发展去中心化 Optimism “Collective” 的非营利组织。(将 OP Collective 视为 Optimism 版本的以太坊社区。)

基金会将收入重新分配给由 OP 代币持有者和其他 Collective 成员投票选出的公共产品项目,如 Optimism 的两院治理模式所定义。自 2021 年以来,Optimism 基金会和更广泛的集体已向各种公共产品计划重新分配了超过 4000 万枚 OP 代币。这些分配的最大受益者是协议公会,在三轮融资中获得了超过 60 万枚 OP 代币。

Gitcoin

考虑到以太坊基金会预算的减少以及终端用户和 dapp 生态系统的不断增长,Protocol Guild 致力于为公共产品创建一种长期融资机制。另一个具有长期潜力支持以太坊核心协议开发的融资机制的例子是 Gitcoin。如前所述,Nethermind、Prysmatic Labs、Lighthouse 和 Lodestar 等几个客户团队过去都依赖 Gitcoin 来获得部分资金。Gitcoin 旨在支持从事开源软件的程序员和开发人员,帮助他们以加密货币为他们的项目筹集资金。

过去的升级

在过去的八年中,以太坊核心开发人员已经执行了 19 次向后不兼容的硬分叉升级。这些升级在复杂性、紧迫性和争议性方面各不相同。其中一次升级导致了永久性的链分裂。另一次升级将整个网络利益相关者群体从网络参与中驱逐出去。每次升级都影响了以太坊治理过程,并将其塑造成如今涉及多个人员、组织和论坛的多方面过程。在本节中,我们将讨论以太坊八年历史中的七个重大治理决策,并进一步研究决策过程中发挥作用的人员、组织和论坛。

就技术问题达成共识

大多数情况下,以太坊核心开发人员会介入,通过 EIP 流程推动和实施代码更改。此外,当出现需要紧急采取行动的意外且时间敏感的漏洞时,他们还会为区块链做出执行决策。以太坊历史上最具争议的决定是 DAO 硬分叉,源于智能合约应用程序 DAO 中的一个意外错误,该应用程序影响了许多 ETH 持有者。在决定如何最好地解决意外技术问题时,以太坊核心开发人员是构思、提出并最终实施解决方案的主要声音。在 DAO 黑客攻击的情况下,以太坊客户端团队实施的解决方案导致了永久性的链分裂,并创建了新的以太坊协议,这说明了以太坊的一个重要特征,即其无需许可的性质,允许任何用户组分叉代码库并启动新版本的以太坊。DAO 黑客攻击还说明了以太坊核心开发人员并不总是一群对以太坊代码库应如何发展有相同看法的同质个体。

以下是三个案例研究,描述了以太坊利益相关者如何就技术问题达成共识:

案例研究 1:DAO 分叉

发生了什么:2016 年 6 月 17 日,当时控制着 ETH 总供应量 15% 的智能合约协议 The DAO 遭到黑客攻击,大约 70% 的资金被盗。此次黑客攻击发生在以太坊推出不到一年后。DAO 旨在成为一种自主风险投资工具,允许 DAO 代币持有者对提案进行投票,并使用基金的集合资本支持各种区块链项目。DAO 是同类中第一个去中心化自治组织。DAO 项目成为当时历史上最大的众筹活动,从 11,000 多名贡献者那里筹集了 1.5 亿美元。

DAO 被黑客入侵是通过一种称为重入漏洞的漏洞进行的,该漏洞允许恶意行为者免费从智能合约中反复提取资金。当恶意行为者从目标智能合约对另一个智能合约进行外部调用时,就会发生这种情况。然后,不受信任的智能合约会回调原始智能合约。每次黑客的合约发起对 DAO 合约的调用时,DAO 智能合约在批准资金转移之前都无法检查和更新其余额。这就是 DAO 合约被慢慢抽干大部分资产的方式。DAO 的创建者一旦发现这个漏洞,他们就会先发制人地开始使用与黑客相同的技术抽干 DAO 合约。DAO 的创建者设法挽救了 30% 的 DAO 资金,但其余 70% 则在黑客的控制之下。

参与者:DAO 项目背后的团队是一群名为 Slock.it 的匿名开发人员。Slock.it 设想 DAO 是一种筹款机制,用于引导其他 dapp 创意,当时 Slock.it 最引人注目的 dapp 创意之一是去中心化的应用程序。在智能合约被利用后,以太坊基金会在有关 DAO 黑客攻击的沟通中发挥了重要作用。在以太坊基金会的博客上,以太坊基金会核心开发人员提出了黑客攻击后未来发展道路的想法,例如实施软分叉以减轻黑客攻击对代币持有者的影响。2016 年,矿工是运行以太坊节点和保护以太坊区块链的个人。因此,他们也是通过升级软件来实施以太坊核心开发人员的任何代码更改的主要支持者。由于该问题的争议性,围绕智能合约代码不变性的激烈辩论,很难从以太坊社区就最佳解决方案达成共识。以太坊利益相关者(包括 ETH 持有者和 dapp 开发者)在 Twitter 和 Reddit 等各种论坛上分享了意见。但是,决策主要通过 ACD 电话会议、Gitter 和 GitHub 进行。

问题如何解决:Geth (EL) 开发者 Peter Szilagyi 于 2016 年 6 月 24 日在以太坊基金会博客文章中提出了通过向后兼容软分叉解决 DAO 黑客问题的初步建议,但在以太坊核心开发者发现这可能导致更广泛的网络受到 DDOS 攻击后,该建议很快被放弃。经过数周的讨论,以太坊核心开发者达成共识,解决 DAO 黑客资金损失问题的唯一技术解决方案是通过硬分叉升级,这将允许 Slock.it 开发者将 DAO 中的所有资金重新分配给不易受到重入攻击的其他智能合约。

发起硬分叉升级的提议首先由 Slock.it 创始人、当时受雇于以太坊基金会的开发者 Stephan Tual 提出。该提案引发了关于“代码即法律”原则的争论,以及以太坊作为区块链的完整性在多大程度上取决于对这一原则的坚持。以太坊核心开发人员于 2016 年 7 月 15 日组织了一次碳投票,以决定是否应在下一个即将发布的软件客户端中默认选择启动硬分叉的逻辑。碳投票是一种链上机制,ETH 持有者可以通过提交零费用 gas 交易来表明他们对治理提案的偏好。DAO 争议是以太坊核心开发人员首次依赖链上碳投票作为收集共识的次要措施。当时总 ETH 供应量的 4.5% 参与了投票,87% 的投票 ETH 供应量投票支持让节点运营商默认选择硬分叉。

黑客攻击发生约一个月后,以太坊客户端团队安排了硬分叉。该提案得到了 Vitalik Buterin 等主要社区领袖和以太坊基金会等组织的支持。此外,当时以太坊的客户端多样性极低。尽管有六种客户端实现,但 97% 的节点运营商都运行 Geth 客户端,这就是为什么当时在客户端团队之间协调客户端升级更容易的原因。

IgFYsFfFV74qHDwhz22UXqzmVMpmtJA1lFQn3vfu.jpeg

通过推进有争议的硬分叉提案,客户团队让矿工和其他节点运营商自行决定接受或拒绝他们的代码更改。硬分叉计划于 2016 年 7 月 20 日启动,即碳投票在链上完成几天后。在 DAO 硬分叉期间,一部分以太坊节点运营商未升级其节点,从而导致永久性链分裂。未接受 DAO 硬分叉升级的以太坊版本现在称为以太坊经典。多年来,以太坊经典一直作为与以太坊并驾齐驱的网络不断发展。然而,由于缺乏安全性和用户参与度,它经历了多次 51% 攻击。在 DAO 黑客攻击后的几年里,以太坊网络在采用率、矿工参与度(即哈希率)以及最重要的价值方面都超过了以太坊经典。

PwVxkExLAFv8SRjIe1rbKskUWHDTKuVomCfswkff.jpeg

在 DAO 硬分叉之后,以太坊仍领先于以太坊经典的主要原因之一是,大多数开发人员(即客户端团队开发人员)继续在以太坊而非以太坊经典上进行开发。自推出以来,以太坊一直是一个具有雄心勃勃的发展路线图的区块链,许多投资者和利益相关者都认识到,这需要一支强大的开发团队来带头。在 DAO 硬分叉期间,主要的软件开发团队是 Geth,而 Geth 开发人员之间的共识是执行硬分叉,将 DAO 黑客攻击的资金返还给 DAO 创建者,这一共识受到当时领导以太坊基金会的傀儡领袖(如 Vitalik Buterin)的影响。Geth 开发人员和以太坊基金会之间的这一共识对以太坊社区和更大的加密行业认为以太坊的适当行动方针产生了巨大影响。

主要收获:DAO 黑客攻击在很大程度上改变了 dapp 开发人员对智能合约开发的方法。在黑客攻击发生几个月后的一次演讲中,Slock.it 开发人员 Lefteris Kaperelli 解释说,所有 dapp 开发人员都应该从 DAO 黑客攻击中吸取的一个教训是,去中心化应用程序需要实现“终止开关”,以保护应用程序免受意外黑客攻击。在 DAO 黑客攻击和其他类似事件发生后,在不可变应用程序中实现可升级性和通过多重签名钱包和治理机构实现否决权的想法已经广为流行。如今,大多数去中心化应用程序都可以在以太坊上升级。

关于以太坊的治理,DAO 黑客攻击是以太坊历史上迄今为止最具争议的问题。这个问题说明了当以太坊社区无法达成一致共识时,以太坊治理机制如何向前发展。它说明了三个主要经验教训:

  • 以太坊决策过程中的否决权落在以太坊客户端团队身上,他们决定对以太坊软件进行哪些更改。但是,一旦达成协议并发布软件,节点运营商就可以接受或拒绝代码更改。当时,主要的以太坊软件客户端是 Geth,Geth 团队、以太坊基金会和 Vitalik Buterin 都支持硬分叉解决方案。因此,他们发布了必要的软件升级,在区块高度 1,920,000 处激活了以太坊的硬分叉。

  • 使用 carbon 投票说明了如何通过链上机制来加强链下治理流程。虽然 carbon 投票不具约束力,这意味着它无权改变开发人员通过 ACD 调用和 Gitter 进行的决策过程,但它确实加强了以太坊社区对执行硬分叉的倾向。

  • 最后,本案例研究说明了以太坊上的节点运营商选择运行哪个版本的以太坊协议的能力和权限。有些人选择拒绝 DAO 硬分叉。然而,正如本报告前面提到的,自 2016 年以来,去中心化金融 (DeFi) 行业的增长导致流动性和 dapp 互操作性的分散,使得以太坊协议的替代版本共存的成本越来越高,技术难度也越来越大。

案例研究 2:Parity 多重签名漏洞

发生了什么:2017 年 11 月,Parity technologies 开发的以太坊最广泛使用的多重签名 (multi-sig) 钱包被意外利用,580 多个用户钱包中价值超过 3.2 亿美元的 514,000 ETH 被永久冻结。漏洞利用者“devops199”在 GitHub 上向 Parity 开发团队发出警报,称他们找到了一种转移控制 Parity 多重签名钱包的智能合约所有权的方法。在试图将合约所有权归还给 Parity 团队时,Devops199 意外触发了与 Parity 代码相关的“kill() 函数”,从而有效冻结了 Parity 多重签名用户的余额。这一毁灭性的漏洞是 2017 年在 Parity 的多重签名钱包中发现的两个主要漏洞之一。

参与者:背景:Parity Technologies 成立于 2015 年,创始人之一为以太坊联合创始人 Gavin Wood。多年来,该公司为比特币、Zcash 和以太坊构建了软件客户端。在多重签名漏洞发生时,Parity 软件客户端是节点运营商使用的第二受欢迎的以太坊客户端。Parity Technologies 后来于 2019 年停止了对 Parity 客户端的支持,将其更名为 OpenEthereum,并将重点转移到构建自己的Layer 1区块链 Polkadot。Polkadot 于 2020 年 5 月在主网上推出。

问题解决方式:为了解锁冻结的用户资金,Parity 开发团队于 2018 年 4 月提出了 EIP 999。EIP 999 将通过硬分叉升级恢复 Devops199 意外自毁的已删除代码。尽管大量以太坊用户受到 Parity 多重签名漏洞的影响,但代码更改从未在升级中实施。在社区强烈反对和反对提议的变更后,Parity 开发人员最终撤回了 EIP。

主要结论:尽管 Parity 是第二受欢迎的以太坊客户端,并且 EIP 999 在以太坊核心开发人员眼中技术完善,但该提案未能实施,因为实施显然会导致另一次永久性链分裂。 2018 年 4 月 26 日,Parity 联合创始人兼首席执行官 Jutta Steiner 在一篇博客文章中写道,该公司“无意因 EIP 999 而分裂以太坊链”。Parity 多重签名漏洞是一个重要的案例研究,突显了以太坊客户端团队对以太坊代码库的影响是有限的。尽管客户端团队是以太坊治理过程中最活跃的参与者,但他们通常倾向于实施大多数以太坊社区都会支持的代码更改,并避开那些很可能重复 DAO 黑客事件的代码更改。

与 DAO 黑客一样,围绕 EIP 999 的争议集中在以太坊代码不变性的争论上。然而,这一次,Parity 客户端团队之外的以太坊利益相关者的压倒性共识是拒绝 Parity 提议的代码更改并保留代码不变性。该共识的一部分是通过为期一周的链上 carbon 投票达成的,结果 55% 的投票者投票反对激活 EIP 999。使用另一次 carbon 投票来衡量更广泛的社区情绪也引发了关于链上投票在以太坊治理过程中的有效性的争论。许多以太坊开发人员和 ETH 持有者认为,由于 ETH 鲸鱼能够利用其持有的资产来扭曲投票结果,carbon 投票是不准确和无效的。除了非正式的 carbon 投票(历史上在治理过程中从未具有太多合法性)之外,EIP 999 还经历了正式的 EIP 审查流程,以太坊客户端团队和更广泛的以太坊核心开发人员群体通过该流程认真讨论了代码更改。自 2018 年 4 月首次提交以来的三个月里,EIP 999 因缺乏社区支持而被多人拒绝。

案例研究 3:君士坦丁堡

发生了什么:第六次以太坊升级,即君士坦丁堡,主要将区块发行量从 3 ETH 减少到 2 ETH,此外还对以太坊代码库进行了一些其他小的技术改进。君士坦丁堡的范围于 2018 年 8 月最终确定,并计划于 2019 年 1 月启动。除了区块发行量减少(也称为 EIP 1234)之外,君士坦丁堡最终确定的范围中包含的其他代码更改包括:

  • EIP 145:创建一种更高效的信息处理方法,称为按位移位。

  • EIP 1052:提供一种优化大规模智能合约代码执行的方法。

  • EIP 1283:为智能合约数据存储的更改引入一种更公平的定价方法。

  • EIP 1014:为基于状态通道和“链下”交易的某种类型的扩展解决方案奠定基础。

在君士坦丁堡升级计划启动前不到 48 小时,一家名为 Chain Security 的区块链安全和审计公司发现了升级代码中的一个错误。经过仔细检查,EIP 1283 将允许黑客使用重新定价的存储操作来操纵智能合约余额。该漏洞的性质类似于 DAO 的漏洞,因为它可以为恶意行为者创造机会对智能合约发起重入攻击。

参与者:Chain Security 于 2019 年 1 月 15 日发布了一篇博客文章,详细介绍了漏洞的确切性质。同一天,以太坊核心开发人员通过 Gitter 和即兴 ACD 电话会议讨论后续步骤。他们很快达成共识,暂停计划的升级,并在下一次定期 ACD 电话会议上决定新的升级日期和软件补丁,该电话会议将于三天后的 2019 年 1 月 18 日举行。在 ACD 电话会议期间,开发人员就升级补丁达成共识,并将硬分叉重新安排在 2 月 28 日激活。以太坊基金会和以太坊 Cat Herders 协助在最后一刻向以太坊矿工和其他节点运营商传达这些决定。这两个组织都发布了博客文章,并联系了社区利益相关者,提醒他们硬分叉计划的最后一刻发生了变化。

问题如何解决:由于问题的性质是技术性的,君士坦丁堡漏洞主要在客户团队中解决。以太坊核心开发人员迅速集思广益,找到了最有效的解决方案,并在他们的软件客户端中实施。与 DAO 黑客补丁不同,君士坦丁堡漏洞的解决方案并没有引起争议,但它确实引发了人们对 EIP 测试过程的担忧,并强调需要加强升级测试工作,以确保在主网上部署之前充分检查新的代码更改。一旦漏洞得到修补,新的硬分叉日期确定,以太坊矿工和其他节点运营商便在 2019 年 2 月 28 日顺利升级了硬件。

主要收获:君士坦丁堡漏洞的解决凸显了社区能够在短时间内迅速团结起来,即时更改以太坊协议,尤其是出于网络安全考虑。由于问题本身缺乏争议,以太坊节点运营商能够在 48 小时内恢复到旧版本的客户端软件。此外,核心开发人员能够在 2019 年 2 月成功激活君士坦丁堡升级的修补版本。原始升级代码中存在错误并没有阻止以太坊开发人员执行升级,而是鼓励他们将更多的时间和资源集中在未来升级的测试上。

凝聚社会共识

当问题源于围绕以太坊社会价值的争议时,决策过程会变得更加漫长和拖沓。DAO 漏洞是智能合约技术故障的一个例子。然而,DAO 硬分叉代表了对技术漏洞的解决方案,该漏洞挑战了以太坊上“代码即法律”的价值,这就是为什么它引起了以太坊核心开发人员的高度争议和不作为。在以太坊的治理历史上,还有少数其他例子,以太坊核心开发人员不得不回应社会问题,这些问题不是技术性的,而是关乎更广泛的社区价值观和信仰。

在下面的两个案例研究中,以太坊核心开发人员故意选择在领导开发方面退居次要地位。他们将大部分决策过程交给了更广泛的以太坊社区,结果,各种以太坊利益相关者的众多声音发生冲突,导致问题和提案的解决延迟。由于以太坊上的社会问题涉及的声音数量多于核心开发人员的数量,因此很难达成共识,而且往往充满不确定的结果。

案例研究 4:ProgPoW

发生了什么:程序化工作量证明 (ProgPoW) 是一种工作量证明挖矿算法,旨在支持效率较低的矿工,并抑制专业矿工的效率。专业矿工是指操作称为专用集成电路 (ASIC) 的专用挖矿机的个人或企业。这些机器经过高度优化,可以完成单一任务,不能轻易重新用于其他任务。图形处理单元 (GPU) 是可以执行一系列不同任务的计算机,因此使用更广泛,购买更便宜。ProgPoW 的目标是使以太坊 ASIC 具有抗性,并防止挖矿哈希算力集中化。几年来,比特币挖矿行业已由主要由资本雄厚、公开交易和受监管的上市公司运营的 ASIC 机器主导。

2018 年 4 月,即以太坊推出三年后,挖矿硬件制造商比特大陆发布了第一款以太坊 ASIC。以太坊社区担心采用 ASIC 技术会导致哈希算力不可避免地集中化,这推动了 ProgPow 的研究和开发。该算法是由一个名为“IfDefElse”的开发团队于 2018 年 5 月在 Ethereum Magicians 上提出的。

尽管在以太坊核心开发人员看来,该提案在技术上是可行的,但以太坊社区对该算法防止 ASIC 主导地位的有效性存在分歧。鉴于 ASIC 只是专用机器,很难构建一种计算机无法进行某种程度优化的挖矿算法。业内其他区块链项目(如 Monero、Ravencoin、Horizen、Ethereum Classic 等)尝试创建抗 ASIC 挖矿算法,但其有效性记录并不一致。鉴于 2018 年 ASIC 在以太坊上尚处于萌芽阶段,社区也质疑这个问题是否真的那么紧迫,开发人员是否应该在其他 EIP 之前通过硬分叉升级来尽快解决。

2019 年 2 月至 3 月,即初始 EIP 提出近一年后,以太坊客户端团队在以太坊基金会和以太坊猫牧人的帮助下进行了多次调查,以确定对 ProgPoW 的支持程度和共识程度。

IvqQpjrXL4KqJjzEq8eC1h925XD1ALfIvRz2fVnM.jpeg

Ethereum Cat Herders)主办的 Twitter 调查,旨在评估对 ProgPoW 的看法。来源:Twitter (@EthCatHerders)

以太坊基金会围绕 ProgPoW 组织了两次链上投票。第一次投票的设计与 DAO 硬分叉前进行的投票类似。它计算投票数时,权重由代币持有者持有的 ETH 数量决定。第二次链上投票旨在调查以太坊矿工对 ProgPow 的看法,方法是允许独立矿工和矿池将数据输入到额外的已挖区块字段中。两次投票都表明,矿工们对代码更改的支持率压倒性地高。当时占以太坊哈希率近一半的矿工参加了第二次链上投票,77% 的参与矿工投票支持 ProgPoW。

以太坊上的矿工大多支持 ProgPoW 提案,因为当时大多数以太坊矿工都是 GPU 矿工。然而,dapp 开发人员和其他以太坊利益相关者并不支持 ProgPoW,因为他们担心该算法的实施可能会导致网络分裂并降低 ETH 的价值。在整个辩论过程中,Vitalik Buterin 等知名以太坊核心开发人员和 Geth 团队成员反复重申,他们对这一变化持中立态度,并将实施社区认为最好的一切。在多次 ACD 电话会议上,以太坊核心开发人员认可了 ProgPoW 的技术可靠性。Linzhi 等挖矿制造公司公开反对升级。

参与者:IfDefElse 是一个由三名开发人员组成的团队,其中两名开发人员使用化名,只有一名开发人员透露了个人身份。IfDefElse 的公开成员是 Kristy Leigh Minehan。当时,她是一家名为 Core Scientific 的区块链基础设施公司的首席技术官。Minehan 参加了几次 ACD 电话会议和以太坊会议,以解释 ProgPoW 算法,尽管该算法引发的争议很快导致 Minehan 淡出了人们的视线。在许多情况下,Minehan 因为她的项目而成为攻击和欺凌的对象。她被指控受 Nvidia 和 AMD 工程师雇佣来破坏 ASIC 挖矿制造商。Minehan 不再从事 ProgPoW 工作。她为资产管理公司 Valkyrie 和加密货币挖矿公司 Merkle Standard 等加密货币公司提供咨询。

问题如何解决:为了解决社区对 ProgPoW 对抗 ASIC 有效性的担忧,以太坊 Cat Herders 宣布他们将筹集 10 万美元,委托独立的第三方对 ProgPow 代码进行审计。从 2019 年 3 月到 2019 年 9 月,Cat Herders 花了大约六个月的时间筹集资金并委托区块链安全公司 Least Authority 进行审计。2019 年 9 月,审计结果公布。审计证实,ProgPoW 算法的设计准确无误,实现了鼓励更大程度抵抗 ASIC 的目标,尽管审计也警告说,正如人们所猜测的那样,未来的硬件进步可能会随着时间的推移降低 ProgPoW 的有效性。审计发布后,以太坊核心开发人员同意将代码更改纳入即将到来的硬分叉中。然而,以太坊社区成员(尤其是 dapp 开发人员)的持续反对引发了争议,阻碍了以太坊核心开发人员优先考虑将 ProgPoW 纳入实际升级。ProgPoW 争论在以太坊社区持续了大约 2 年。2020 年 3 月,在 ACD #82 期间,开发人员就代码更改进行了最后一次公开讨论。在那次电话会议中,开发人员表达了他们对社区对 ProgPow 缺乏支持的担忧,并因此决定将其排除在下一次硬分叉之外。

主要结论:ProgPoW 并未解决以太坊的技术漏洞、黑客攻击或问题,这些漏洞或问题会影响大量 ETH 持有者或以太坊网络本身的安全。ProgPoW 开发的主要推动者是矿工,他们的声音历来很弱,而且由于自以太坊推出以来就一直存在通过将以太坊过渡到 PoS 强行将矿工从网络中移除的努力而被忽视。每次以太坊核心开发人员提出减少区块发行(例如 EIP 1234)或以减少矿工收入的方式进行更改(例如 EIP 1559)时,矿工的反对从未动摇以太坊核心开发人员的意见或情绪。因此,旨在从技术优点的角度审查和推进变更的治理流程并没有帮助 ProgPoW 得到激活,支持变更的个人在以太坊生态系统中没有影响力。

尽管有链上投票和以太坊核心开发人员的技术批准,但 ProgPoW 辩论说明了如果没有来自终端用户和 dapp 开发人员的更广泛社区支持,一群网络利益相关者将无力改变以太坊。以太坊核心开发人员并不反对代码更改,但他们发现很难优先考虑有争议的升级,而要牺牲其他相对较少争议且获得更多以太坊终端用户支持的代码更改。此外,随着以太坊核心开发人员从 2021 年初开始将注意力转向 PoS 并弃用挖矿算法,对 ProgPoW 的需求逐渐减弱。

案例研究 5:Afrigate

发生了什么:以太坊核心开发人员被以太坊社区驱逐的情况并不常见

声明:所有在本站发表的文章,本站都具有最终编辑权。本站全部作品均系微算力原创或来自网络转载,转载目的在于传递更多信息,并不代表本站赞同其观点和对其真实性负责,所产生的纠纷与本站无关。如涉及作品内容、版权和其它问题,请尽快与本站联系。

相关推荐

  • 微信:aspcool
  • QQ:580076
  • 手机:18992859886
  • 工作时间:9:00~18:00(周一至周五)