火星链 火星链
Ctrl+D收藏火星链

GETH:观点 | 五问以太坊:客户端多样性问题从何而来?如何解决?

作者:

时间:1900/1/1 0:00:00

最近举行的第90期核心开发者会议几乎全程都在讨论一个问题。我强烈建议大家亲自听一下这场会议。

在这场会议上,Alexey提出了客户端开发者负荷过重的问题。虽然我认为这场讨论是一个重要的开始,但是我们太急于寻求解决方案了,充分理解这个问题才是当务之急。重要的是,我们需要花点时间来分析问题。在问题内涵的分析上,“五问法”是最简单有效的方法之一。

事不宜迟,先来看看第一问是什么。

第一问:为什么Geth开发团队的压力如此之大,甚至到了超负荷的地步?

通过etherscan,我们可以看到各个客户端的装机量所占份额的统计数据如下所示:

Geth:75%

Parity&OpenEthereum:20%

Nethermind:1%

剩下4%由一些市场份额不到1%的客户端组成,因此忽略不计。

重要的是,有超过51%的算力都集中在Geth客户端上。假设在即将到来的柏林硬分叉中,Geth在实现其中一个EIP时出现了bug。即使这个客户端的其它实现都没出bug,只要有区块碰上了这个bug,就会导致以太坊网络分叉。按理来说,这个区块是无效的,其他客户端也会将其视为无效块。但是,有超过51%的挖矿节点都运行的Geth客户端,因此整个网络都会被带到错误的分叉链上去。

观点:最符合SEC标准的就是那些无IXO(预售)方式的POW币:微博用户“BCH爱好者BruceLee”通过微博表示:从SEC起诉XRP这事里面我们可以看出,所有加密币里面,最符合SEC标准就是那些无IXO(预售)方式的POW币。所以我们看到灰度和PayPal的F4,都是POW币: BTC、ETH、BCH和LTC。而星展银行估计是被XRP的公关给忽悠了(XRP很擅长和银行打交道),把F4里面的LTC换成了XRP,开局就踩雷,真是悲剧。而ETH初始发行方式其实本质是和IXO是一样的,都是预售模式。不过ETH生态强大,绑定了太多利益方,光是稳定币市值就差不多200亿刀。SEC要动XRP,大家都上去踩一脚。SEC如果想动ETH,估计会遭到币圈强烈反对,所以ETH安全的很。

但是其他搞预售的币(现在大多数币都是预售模式发行的),都有被SEC起诉的风险,只不过当市值很小的时候,SEC应该注意不上。

如果SEC这次搞完XRP就暂时消停了,大家可以松口气。如果搞完XRP立马搞下一个(有传闻说要搞Link,不知真假),那么对币圈所有搞预售起家的币都是重大利空。大家可以检查一下自己的投资组合里面,有哪些币当初是IXO方式发行的,提前做好准备。[2020/12/24 16:23:27]

这就要求Geth客户端和开发团队绝对不能犯错。

观点:比特币每次上涨周期都需要更长时间才能结束:投资基金DTAP Capital创始人Dan Tepiero称,要准备对比特币保持耐心。每次上涨周期都需要更长的时间才能结束,而且随着美元绝对价值大幅上升,其走势也不那么极端。6-12个月后价格可能会也肯能不会崩溃破裂。(Cointelegraph)[2020/8/29]

因此,第一问的答案是:

因为以太坊网络的客户端缺乏足够的多样性。

值得一提的是,客户端多样化不会突然将客户端开发变成一项轻松的工作。但客户端多样性本身依然是一个值得探索的领域,有助于我们找到提高客户端开发的效益,同时减轻开发团队负担的方法。不可否认的一点是,只在Geth团队上下功夫不太可能解决这个问题。

第二问:为什么以太坊网络缺乏客户端多样性?

以太坊主网上线时,我们有多个客户端。其中最主要的两个是Geth和CPPEthereum。之后又出现了Parity,CPPEthereum被淘汰。

观点:ETH一旦突破306美元,可能会大幅上涨:加密货币交易员Josh Rager在推特上表示,以太坊(ETH)价格一旦突破306美元,可能会大幅上涨。他还称,现在购买以太坊与在2017年上涨之前购买以太坊一样,当时以太坊和比特币不仅分别达到了1,300美元和20,000美元的历史高位,而且许多山寨币价格也暴涨。(U.Today)[2020/7/7]

从那时起,除了Parity之外,没有一个客户端能获得较大的市场份额。去年,Nethermind异军突起,成为了一颗冉冉上升的新星,但是目前只占据了1%的市场份额。最近,由于Parity遭遇了一些波折,前途一片黯淡,Parity的市场份额大幅下降。我们认为,在理想情况下,以太坊网络需要有3个及以上的客户端、每个客户端占有的客户端份额都不至于太高、没有任何一个客户端能占据远远超过51%市场份额。虽然在理想情况下应该实现客户端多元化,但是我们已经习惯了客户端霸权的局面。

那么,我们为什么需要多个客户端?

观点:随着BCH、BSV减半,两者算力将开始转向BTC:Dragon Industries的Arthur van Pelt在推特上表示,比特币目前占据了93.8%的算力。当BCH的区块奖励减半至6.25 BCH时,它只拥有总算力的1.5%。随着BSV亦将减半,其目前2.7%的算力占比可能会进一步下降。这是一个可以预测的场景。比特币目前的价格甚至还达不到Antminer S9等许多老矿机的盈亏平衡点。Poolin(币印)矿池副总裁Alejandro de la Torre对此表示,BCH矿工与BTC、BSV矿工使用相同的算法,因此矿机也通用。BCH算力下降了一半,BTC的算力上升了(BSV算力的上升幅度几乎可以忽略不计),这表明矿工已经转向比特币,因为开采比特币更有利可图。(Bitcoinist)[2020/4/9]

从我个人的经验角度来看,构建以太坊客户端难比登天。Geth之所以能在以太坊网络上稳定运行,是因为它引入了很多复杂的优化。Geth团队花费了数年时间才达到了如此高的复杂度,目前仍在继续优化中。

声音 | 观点:应提请全国人大常委会增加数字货币的相关条款:1月23日,南财经政法大学教授乔新生在证券时报发文《中国金融立法需要考虑五个问题》。文章指出,中国金融立法应当重点解决以下几个关键问题:

1.关注我国金融体制改革问题;

2.金融市场监管必须加强对货币的监管;数字经济时代,货币一定会进化为数字货币。中国人民银行应当考虑加快我国数字货币研发工作,并且提请全国人大常委会在中国人民银行法或者货币法中增加有关数字货币的相关条款,从而为我国数字货币的发行和流通打下坚实的法律基础。

3.坚持储蓄经济发展模式不动摇,坚持保护居民存款不动摇;

4.建立在储蓄经济基础之上的金融法律体系具有独特性。居民将自己存款存入银行,银行必须担负起特殊的责任。;

5.金融监管水平高低关键在金融人才。[2020/1/23]

有人可能会立即建议我们想办法为落后的客户端提供支持和帮助。我很警惕这种“人月神话”式的解决方案——在软件开发过程中,让更多工程师来解决一个难题很少会成功,而且我不指望这种方案会取得成功。

相反,我认为应该将关注点放在复杂性上。

注:人月神话,mythicalman-month,指出以大量人员和较短的时间,并不能缩短软件的开发进度。一窝蜂的作业方式无助于软件生产,且会制造麻烦,产生出更差的软件。向进度落后的项目追加人力,只会使进度更加落后。

第三问:为什么构建以太坊客户端会这么难?

现在,我们正越来越接近问题的根源。

事实证明,大部分困难都来自于组网协议,即以太坊客户端软件用于相互连接并分享区块链信息的那一组工具。以太坊的组网规则,最终影响甚至决定了以太坊客户端的设计和要求。

一些组网工具指定了未经优化的架构,甚至要求以太坊客户端运行不必要的功能。客户端开发者需要在这些限制下工作。

第四问:为什么网络互联协议提高了客户端实现的难度?

我相信,这个问题的答案基本上可以分为两个部分。

状态管理

整体网络互联要求

就状态管理而言,以太坊客户端必需能够同步网络上的完整状态,并维护该状态的本地副本。这两点都很难做到。对客户端以及读取并处理状态要求的服务器来说,同步状态需要提出数百万个请求,并且会导致磁盘I/O饱和。新同步的状态需要经过维护和删减,以便数据库能足够快地执行新区块。从工程上来说,这是一项严峻挑战!

GetNodeData是我们用来同步状态的唯一网络互联工具,针对特定的状态数据库格式进行了优化。由?TurboGeth?推广的“扁平式”数据库布局在状态维护方面具有极大的性能优势,但是使用这种布局会加大?GetNodeData?请求的处理难度。

一旦我们将注意力转向网络技术,尤其是DevP2P?ETH?协议,我们会发现还有其他因素提高了客户端的复杂性。要想加入这个网络,客户端需要具备以下能力:

处理访问最近区块所生成的状态的?GetNodeData?请求;

处理访问链上数据历史记录的请求,包括区块头、区块体和收据。

从根本上来说,对于许多客户端操作而言,处理这些请求所需的基础数据不是必需的,但是现在却强制它们支持这些功能。这就需要所有客户端在除了满足自己本身的需求之外,还要另外构建大量功能。例如,主要作为交易发送网关的客户端并不需要历史链上数据,可能只需要一个很小的状态子集。但是,就当前的以太坊版本而言,客户端依然需要保存完整的副本。

第五问:为什么……

看来我只问了四个“为什么”就找到了根本原因。以太坊协议还没有完全成熟。在设计以太坊协议时,我们并没有意识到现如今发现的大多数问题,或者因为当时状态规模较小、发展历史较短,这些问题还不成问题。

解决方案

过去一整年,我都在关注这个问题。令我震惊的是,以太坊上许多问题的根源其实都可以追溯到网络层。

或许最明显的例子是,磁盘I/O历来都是客户端的一个瓶颈。这个瓶颈之所以存在,是因为客户端倾向于使用树结构的朴素表示来执行其状态数据库。状态数据库的构建方式由?GetNodeData?网络元件决定。

为了解决这个问题,我们需要对以太坊共识层以及网络层的各个部分进行检修。目前,检修工作已经启动。大量工作已经在Alexey和我共同领导了8个月的“无状态以太坊”名义下开展。我们所做的一些工作至少减轻了Geth团队的负担,因为他们用上自己开发了经年之久的SNAP同步协议。还有一部分工作需要深入理解这个问题并想到可行方案的才俊来承担。

目前,这样一个庞大的DevP2P?ETH?协议尚未完全解构。我们对于如何将这个网络拆分成三个独立的专用网络有了基础了解,但是目前还没有人直接着手这块。

另外,还有像?re-genesis?之类的想法,提供了完全回避这些问题的机制。这是一种激进的方法,如果能成功的话,或将为我们带来很大的优势。

首先,我们应该清楚的是,以太坊网络还有许多艰巨的任务需要完成,只有少数人能够胜任这些任务。虽然每天都有越来越多的开发者参与进来,但是他们需要投入时间和精力来学习必备技能。客户端开发者在专注于解决日常用户看不到的底层问题时,还要抽出时间来开发新的EVM功能。

如果我们希望以太坊网络能够取得长远的成功,我认为整个社区都要就解决这些问题展开合作,给予其根本原因足够的关注和讨论。最重要的是,我们要携手打造出有效的技术解决方案。

原文链接:?https://snakecharmers.ethereum.org/applying-the-five-whys-to-the-client-diversity-problem/作者:?PiperMerriam翻译&校对:?闵敏&阿剑

标签:ETH以太坊GETGETHEtherBack以太坊币最高价格是多少下载BitGet官方网站togetherbnb游戏官网

比特币价格热门资讯
CBD:世界经济论坛(WEF):到2030年,区块链将在能源等领域创造300亿美元的机会

世界经济论坛发表的一份报告强调了第四次工业革命技术的关键作用。在COVID-19爆发后,区块链等新技术可以通过实施“自然积极型”解决方案来帮助刺激增长.

1900/1/1 0:00:00
YEA:观察丨如何利用“聚合三要素”让DeFi协议捕获价值

本文来源:金色财经作者:Jason聚合平台就是这样一个能够与用户形成直接关系的平台,可以用零边际成本为用户提供服务,并通过供需之间的良性循环来降低用户获取成本.

1900/1/1 0:00:00
比特币:读懂哈希率“炼金术”:比特币算力资产的特征与挑战

撰文:LeoZhang与KarthikVenkatesh,分别为算力及衍生产品研究机构AniccaResearch创始人与数据分析师科学方法试图了解事物的本质.

1900/1/1 0:00:00
区块链:2020年区块链专利排行榜TOP100:52家中国企业上榜,阿里腾讯位居前二

作者|任万盛出品|零壹智库&数字资产研究院据零壹智库数据显示,截至2019年末,全球累计有47个国家和地区、5926家公司申请了38064件区块链专利;其中,有3218家公司来自中国.

1900/1/1 0:00:00
ASH:数字化契约如何守护?解析盲签名的妙用

作者:廖飞强|微众银行区块链核心开发者来源:微众银行区块链微信公众号数字签名在数字契约中包含不便公开的敏感信息时,如何进行有效的签名?签名时看不到信息明文.

1900/1/1 0:00:00
加密货币:第一家上市的加密资产交易所?Coinbase的上市之路可能不会那么顺利

作为最早拿到纽约金融服务部门加密许可牌照BitLicense的加密货币交易所之一的Coinbase,不仅在纽约州获得了官方认证,还与多家美国政府机构的关系非常密切.

1900/1/1 0:00:00