编者注:本文为AlexeyAkhunov介绍以太坊1.x理想开发流程的一篇文章,既总结了现有开发流程中的一些局限,也列举了新开发流程可能会面临的一些挑战。大家都知道公链治理很难,但作为外围人员,通常也并不清楚其中的流程到底是什么样的,我们能做的也只有尽可能展现他们的工作氛围,然后为值得信任的开发者争取他们应得的支持。
题目中所说的“流程”指的是修改以太坊规则的流程。关于规则的修改情况,下面有几个例子:
新增EVM操作码
更改GasSchedule
取消某些规则
更改某些数据的含义和某些操作的作用
免责声明
我不想在行文过程中涉及太多的细节,因此下面的插图省略了一些重要的团队和人员,并且有意无意地省略了整个流程中的一些步骤。如果你觉得我遗漏了很重要的内容,请告诉我,在此先谢过了。你也可以在我给出的流程上进行修改,重新发布你自己的一版!
CertiK:Army of Fortune项目Discord服务器遭入侵:金色财经报道,据CertiK官方推特发布消息称,Army of Fortune项目Discord服务器遭入侵,有黑客发布钓鱼链接。在团队宣布服务器恢复安全之前,请用户勿与任何链接交互。[2023/6/27 22:02:26]
我个人总结的流程
网络中的人产生了修改以太坊的想法,于是写了EIP。大多数想法到这一步就没下文了。
如果三个客户端实现团队之一注意到了一些EIP,就会把它们挑出来创建原型,并做出进一步评估。我在图中列出了三个实现团队,每个都有其特殊性和重要性:
Parity?——第二大常用实现,不过矿池明显用的最多。
Geth(go-ethereum)?——?第一大常用实现。
美OCC代理署长:同时实现去中心化、安全性和规模化对于公共区块链是不可能的:6月18日消息,美国货币监理署 (OCC) 代理署长Michael Hsu周五在美国银行家协会的一次活动中表示,资产代币化是金融未来的重大进步,但去中心化区块链可能存在太多问题,无法应对这一趋势。他认为,代币化不需要权力下放和去信任,同时实现去中心化、安全性和规模化对于公共区块链是不可能的。
Hsu称,加密行业在很大程度上仍然是自我参照的,并且与现实世界脱节,尽管多年来一直处于主流聚光灯下,他们宣扬数十亿美元的风险投资和数百万小时的代码承诺,但该行业不成熟且充满风险。[2023/6/18 21:45:36]
Aleth(原生C实现)?——目前唯一一个能够“生成”共识测试的实现。
简而言之——如果上述三个团队有意向为某个EIP创建原型,这个EIP就有可能实现。
安全团队:“Fake_Phishing7945”地址将20枚ETH转移至Tornado Cash:金色财经报道,据CertiK监测,在Etherscan上被标记为“Fake_Phishing7945”的0x649bE2b开头地址已将资金存入0xA1625F9开头的钱包地址,该钱包刚刚向Tornado Cash转移了20枚ETH(约3.1万美元)。
目前,0xA1625F9开头地址仍然持有46.6枚ETH(约7.26万美元)。[2023/1/17 11:16:21]
在拜占庭硬分叉到君士坦丁堡升级这段时间内,客户端实现必须完成大量工作,确保其性能能够负担增多的交易量和状态量。这可能就是君士坦丁堡升级实际上没有做出什么重大改变的原因之一,因为这需要投入大量研究和/或实现。
ETC全网算力突破60TH/s,续创历史新高:9月14日消息,据2Miners数据显示,当前ETC全网算力为61.14TH/s,续创历史新高。[2022/9/14 13:28:57]
原型实现通常会让EIP变得更加细化和完善,有时候会因为出现问题而被放弃。原型实现还会降低创建测试向量——描述有可能改变规则的各种场景——的难度。
测试向量需要按照特殊格式编写,有时被称为“fillertest”。这里有一个例子。
我之前说过Aleth(C)实现比较特殊。原因是,在fillertest编写完成之后,将其转化成共识测试的工具是与Aleth紧密耦合的。整个过程等于是让EIP在Aleth中的实现变成了实现范例。以这种方式生成的共识测试也可以在大多数其他实现中运行。
Ripple回应SEC关于Hinman电子邮件裁决的反对意见:金色财经消息,Ripple公司称,法院必须拒绝美国SEC对Hinman电子邮件裁决的反对意见。Ripple和个人被告Brad Garlinghouse和Chris Larsen已经提交了他们对美国SEC反对法院最近关于披露前高官William Hinman的以太坊演讲相关电子邮件的裁决的答复。 被告要求法官拒绝SEC的反对意见。 治安法官Sarah Netburn迄今已发出三份命令,迫使该机构出示有关文件。据U.Today报道,法院在1月份裁定该机构必须交出Hinman的电子邮件,因为该机构辩称这些邮件受到蓄意程序特权(DPP)的保护。4月,Ripple公司又取得了重大胜利,Netburn法官拒绝了原告的复议申请。[2022/8/10 12:15:34]
测试团队也很特殊,因为大多数测试向量都是他们创建的。
虽然整个流程到这还没结束,但我就不画示意图了。客户端实现使用共识测试找bug。共识测试也用来驱动“Hive”中的测试。这里面还涉及到模糊测试。然后还有测试网。
以太坊1.x或将采用的流程
以太坊1.x不会让已有的实现团队按照主观意愿来处理改进提议,可能会专门创建一个工作组来负责这块。虽然并没有降低其中的难度,毕竟要找到愿意处理这些改进协议的开发者、愿意为此付费的人等等。不过,这个流程至少划分了职责,并且增强了流程的可扩展性。
工作组选择一个成员最熟悉的客户端实现,然后通过这个客户端实现来创建一个实现范例,再由这个范例实现产生出EIP和测试向量。目前,这个步骤已经可以实现。
目前尚未实现的是如何通过非Aleth参考实现来生成共识测试。不过,我们希望能够将新工具“retesteth”集成至最流行的实现中。最初,我想过要为此专门创建一个工作组,不过后来意识到不如直接做来的快一点。点击此处,查看我们目前正在进行的开发工作。
获取人力和资金支持
我们如何为这些工作组找到成员呢?如何为工作组寻求资金支持?这些都不是小问题,但是我们尚未找到答案。我认为目前主要面临两大挑战:
我们的人才来源非常有限,可能是因为我们的“核心开发”在外人看来有点像是黑暗艺术。我认为应该加强自我描述和用户教育。后面我会另外写一篇文章。
我们需要从不同的角度来看待资金支持,一方面是持续资助实现团队的工作,另一方面是资助更多具体的临时性方案。还需要解决一些问题。例如,应该将“尽职调查”和监督控制在什么程度内?谁可以决定工作组是否完成交付?诸如此类。这些问题都是可以解决的,之后会另外写一篇文章。
Ethereum2.0会采用什么样的流程?
以太坊的进化之路原本是PoW->PoW/PoS混合机制->PoS->分片,却在2018年6月全部推翻重写。我怀疑这一历史性转折的原因之一是以太坊的改进进程太过缓慢,无法赶上Casper和分片的开发进度。
很多系统在演化过程中都会出现这种转折点。通常是因为原有系统不堪应对挑战,或是维护原有系统的工程师开发进度不给力。我认为只有才满足下面至少一种条件的情况下,这种转折才能获得成功:
1)需要比原有开发团队更富有经验和能力的团队来执行新的进程
2)开发和改进进程经过了彻头彻尾的改变,能够解决原定进程所面对的挑战
我认为,以太坊2.0尚未与新的开发和改进计划接轨,不过我们不知道这个流程实际会是什么样子。因此,我猜想人们可能还是会回归以太坊1.0的流程。然而,这正是以太坊2.0想要避免的。
我想说的是,人们都低估了投资以太坊1.0的开发和改进进程的重要性,只有这样才能为以太坊2.0打下一个良好的基础。当然了,要是以太坊2.0一开始就完美无缺,不需要改进的话,这些就都不成问题了:)
结语
我认为以太坊1.x不仅仅是一组路线图,而是以更高效和包容的方式改进以太坊的尝试之举。这篇文章大致表述了我的想法。
原文链接:
https://medium.com/@akhounov/ethereum-1x-as-an-attempt-to-change-the-process-783efa23cf60
作者:AlexeyAkhunov
翻译&校对:闵敏&阿剑
本文由作者授权EthFans翻译及再出版。
郑重声明: 本文版权归原作者所有, 转载文章仅为传播更多信息之目的, 如作者信息标记有误, 请第一时间联系我们修改或删除, 多谢。