事件经过
北京时间2020年11月11日下午,以太坊社区知名的节点服务Infura被曝出API服务出错,并因此导致了多个依赖于Infura来构建的服务的崩溃,或者前端显示不正确。
就Infura自身而言,可以把它理解为一个公开的以太坊节点,这个节点会接收请求并返回一定的服务,比如帮忙转发交易、比如检查某笔交易上链了没有,又或者某个账户的状态如何。实际上,只要自己部署一个以太坊节点,就能提供跟Infura同样的服务。但它的特殊性在于,Infura的大部分服务都是免费的,因此很多服务都选择了依赖Infura来向自身播报以太坊区块链的状态,免去了自己部署节点的麻烦。
也正因此,Infura出错,理论上波及面会很广,在事件发散的过程中,甚至还有人扬言“以太坊会分叉”。理由是两个不同的区块浏览器上,对同一个块高显示了两个不同的区块。
但很显然,以太坊根本没有分叉。从事实上来说,两个区块浏览器所显示的后续区块都是相同的,这表示出块的矿工没有以两个不同的区块为父块来继续挖矿,也没有彼此拒绝对方的区块。从理论上来说,只有出块的节点彼此之间使用了不同的共识规则,且都占据了一定的算力,才有可能形成分叉。
观点:比特币与其他资产的长期相关性可能继续较低:富达数字资产(Fidelity Digital Assets)最近的一份报告总结称,基于过去五年的数据,比特币(BTC)与主流金融资产的价格相关性很小。在2020年的过程中,比特币进一步被主流金融所采用,这可能会影响资产的相关性。该机构研究总监Ria Bhutoria称:“比特币在较短的时间内,尤其是在不确定性和动荡时期,甚至到2020年之前,与其他资产的正相关性更高。”Ria Bhutoria表示,比特币和其他资产之间相关性的增强是短期流动性危机的结果,影响了许多资产类别。她说:“鉴于比特币与其他资产类别的风险和回报因素不同,以及它的动态使用案例和叙述,比特币与其他资产的长期相关性可能继续较低。”(Cointelegraph)[2020/10/25]
事实上,人们很快就发现了,这是因为Infura没有运行最新版本的Geth客户端,而某些特殊的交易触发了这个版本的客户端的bug,使之宕机了。Blockchair也是同理。所以很快就有人出来呼吁大家尽快升级Geth客户端。
观点:DeFi行业需要自我监管:COMEX前董事长、纽约天使基金会的董事会成员Donna Redel和芝加哥肯特法学院兼职教授Olta Andoni今日在CoinDesk刊文称:“我们认为,DeFi行业需要自我监管,否则将面临严格的监管审查和声誉风险。DeFi热潮和2017年最初的ICO泡沫有相似之处,即疯狂交易,出现了很少或根本没有经过测试和审计的项目;目前尚无明确的监管指南,且以太坊gas费用上涨。从证券法和商品法的角度来看,许多问题都应该重新研究,以了解它们如何适用于去中介化、去中心化的金融模型以及如何对其进行重新构想。 我们认为,DeFi需要创建一套新的行业规则,包括审计,适当的风险披露以及计划在实际发生问题之前预测可能出了什么问题。DeFi的自我监管应规范抵押品充足性审查、审核标准、持续和危机基础上的治理、以及代币以发行为中心的所有权。”[2020/8/25]
至北京时间11日18时,Blockchair团队的NikitaZhavoronkov@nikzh发表推特,解释事件的因果关系:
观点:安全是DeFi持续增长的最大挑战:区块链安全公司Quantstamp的创始人Richard Ma表示,DeFi有可能改变我们的金融生态系统,但安全仍然是一个巨大的挑战。他称,安全对DeFi的发展至关重要。仅今年一年,DeFi项目就有价值2600万美元的资金被盗。虽然DeFi项目承诺金融包容、提高利率、降低成本,但许多项目在安全方面仍然缺乏,用户资金存在严重漏洞。(Coindesk)[2020/7/9]
以太坊开发者某一次对代码的更改导致了当日以太坊区块链的分裂,分裂自区块高度11234873开始;
没有更新客户端的服务商,包括Blockchair和Infura,就因此受害,被留在了一个少数人组成的链上
从技术上来说,这意味着发生了一次“未公开的硬分叉”
修复措施是升级geth客户端并运行debug.setHead(11234872)
他还表示,这件事绝不该被低估,应该被认为是TheDAO事件之后,以太坊区块链上最严重的一次事故。
观点:股市大概率会回调,或致比特币同步下跌:管理资产达1350亿美元的DoubleLine Capital首席执行官Jeffrey Gundlach表示,股市跌回3月低点的几率为76.8%。因为本轮反弹没有得到机构资金的支持,主要是来自散户,Robinhood等提供零交易佣金账户的服务有大量新交易员涌入,他们在2020年3月股市崩盘时抱着逢低买进的心态入场。这一情况让股市面临着遭遇严重回调的风险。若对股市不利,比特币也会受到影响。这是因为,自2020年3月全球市场崩盘以来,两者之间的正相关性正在增强。撇开几天的脱钩不谈,比特币和美国股市都曾双双下跌并同步回升。(Bitcoinist)[2020/6/10]
确实很奇怪,为什么会有某个错误仅仅导致软件在某个时间以前的历史版本崩溃而现有版本不崩溃?这岂非意味着,不同版本的geth客户端的共识规则实际上不一样,也就是某时某刻发生了一次不能向后兼容的共识规则改变?此外,一个Infura的崩溃就导致了大面积的服务出错,这是否意味着Infura已经成了一个“单点故障”来源?
观点:加密货币交易存在大量且持续的套利机会,主要由投机者推动:过去10年的经历表明,尽管比特币存在波动性,但它是世界上第一种、也是最主要的加密货币,是一种非常稳健的长期资产。最近一篇题为《剖析加密货币市场的时变风险敞口》(Dissecting Time-Varying Risk Exposures in Cryptocurrency Markets)的论文称,“比特币与大多数法定货币不相关,波动性更大,因此在风险管理和多样化方面的用处有限。”不过,论文指出,虽然比特币作为避险资产的说法在现实中可能没有完全建立起来,但数字资产市场中的投资者仍有机会,“相对于不同交易所的法定货币,加密货币交易中存在大量且持续的套利机会,加密回报动态主要由‘投机’的投资者推动。”(AMBCrypto)[2020/6/1]
缘由
针对上面的两个问题,Geth客户端团队的领导者PéterSzilágyi@peter_szilagyi都有回应。
从技术上来说,的确可以说是发生了“未公开的硬分叉”,但这只是因为开发人员修复了一个沉睡了两年多的bug,而因为担心公开披露这个bug会导致以太坊遭到攻击,所以选择了静默修复。
人们也不该鄙视Infura没有使用最新的Geth客户端。从运营者的角度,不紧跟软件的最新版本是理性的。而依赖于Infura的服务,是自己把这个权利交出去了,而不是别人禁止了你运行节点,所以也没什么可抱怨的。
Peter的回应也引起了不同的反应。一位门罗社区的人表示,在2017年,他们也曾因为同样的顾虑而选择了静默修复bug。当然,也有人认为,选择静默修复是对的,但至少应该通知大型基础设施的提供者,只要联系了,就能大幅减少这一漏洞所造成的破坏。
北京时间12日凌晨5:34,Peter发布了《Gethv1.9.17客户端所造成破坏的事后报告》,定位了问题的来源:发布于2019年11月7日的Gethv1.9.7错误实现了EIP-211;JohnYoungseokYang在2020年7月15日报告了该问题,于是Geth团队在7月20日更新的v1.9.17版本中修复了这个问题。该次修复使得Geth客户端在执行涉及相关规则的交易时能跟其他以太坊客户端相一致,但却使v1.9.17版本与历史版本的Geth发生了不一致。
如Peter所述,这个过程完全不是为了引入某个以太坊社区不知道或者不同意的共识规则,仅仅是因为写了bug所以必须修复bug。除非你管写了bug也叫“硬分叉”,否则就没有理由管修复bug叫“硬分叉”。
其次,到底怎么发布修复,实际上并不简单。以太坊的硬分叉协调也需要很长时间。如果公开一个带有严重危险性的bug,在各节点升级的过程中难保不会有人尝试攻击。作为客户端开发者,他考虑的更多是以太坊网络的安全性,而不是某个服务的安全性。而且,他们也并不是对所有的bug都采取同样的静默修复措施,很多都是公开修复的。
12日上午7:11,Optimism团队的JingishiringforOptimism@jinglanW出来披露了更多信息:他们在6个月前复制了Geth客户端的代码库来研究和开发OptimisticVirtualMachine,在该过程中,他们发现了一个神秘的bug,也修复了该bug,但一直无法定位其来源;他们一直以为,这个bug可能跟团队引入的定制化改进有关,但11号他们开始怀疑错误就存在于旧版的geth客户端中,而不是因为他们引入了一些改进。于是他们看了ethernodes.org显示的节点分布之后,就决定在主网上测试该bug。因此有了后面的事情。
所以,实际上,是Optimism团队发现了一个bug,草率地决定在主网上测试该bug还存不存在,再加上Geth团队此前选择了静默修复该bug,才使得某些没有及时升级的节点出错了。
该如何理解和看待这件事情呢?
就事情的本因来看,这是因为客户端团队选择了静默修复一个沉睡了许久的bug。虽然很多人认为geth团队可以通过联系基础设施提供者来降低破坏,但我在这里还是认为,我们应该给客户端开发人员更多的信任和尊重。我相信Geth客户端团队这么做是有理由的,他们知道绝大部分节点都在使用自己的软件,也考虑了bug的沉睡时间,因此选择了静默修复。从事后诸葛亮的角度,当然提前通知了大的基础设施提供者会更好,破坏会更少。但是,这样吹毛求疵合理吗?为什么依赖于Infura的服务不假设Infura可能崩溃?
我承认我在这里不太公正,但更公正的话,也有很多人已经说过了。我在此只想表达我对geth客户端团队的敬意。我愿意把印象分给他们,因为他们在过去提供了许许多多的工作量证明。他们值得大家的尊敬。
在静默修复措施的执行上,当然存在提高的空间,也应该跟包括门罗和比特币社区学习经验。但如果只想着谴责geth团队,乃至以阴谋论来揣度他们,那才是更大的不公正。
关于“Infura是否成为了单点故障的来源”,也分简单的回答和复杂的回答。简单的回答是,不是,因为就像Peter所说,从来没有人禁止你部署节点,只是很多提供商自己选择了外包。Infura不是设计层面上必须经过的一个单点。只是因为各种各样的原因,它成了可能是最大的节点服务提供商。
但复杂的回答是,以太坊节点的资源消耗比较大,确实是一个被低估的问题。以太坊协议的运行需要各节点完全执行区块中包含的交易,而执行交易必须从状态数据中取出数据、并且完成后也要将结果写入,这个过程会涉及大量的硬盘随机读写。而且,随着状态数据体量的扩大,读写的效率要求也会提高。前些年热议的“状态膨胀”问题,在当前的以太坊上还没有解决。运行节点的门槛高,节点的数量自然就少。从善意的角度看,如果以太坊节点的运行门槛降低,我相信会有更多人自建节点,而不是选择依赖于Infura。
但这个问题的解决,同样依赖于以太坊客户端开发者和研究人员的智慧。无状态性,可以说是解决状态膨胀问题的终极方案。而在终极方案变得可行之前,我们仍然需要客户端开发者,为我们贡献更高效率的客户端。
所以,确实发生了一件事,也确实暴露出了一些问题、指出了我们学习和进步的方向。但解决这些问题,离不开我们对社区中不同团体的理解和尊重。远离阴谋论,远离恶意和自作聪明的嘲讽,弄清楚问题的根源,思考其实质和改进方案。我们做的事情,才决定了我们是谁。
原文:TheBlock,原文作者:WolfieZhao译者:Odaily星球日报Moni 内容概述: 1、本文撰写时,据Coingecko数据显示比特币价格已经达到18,317.34美元.
作者:阿剑 自《Arollup-centricethereumroadmap》一文发表以来,整个社区都对以太坊的路线图产生了疑问.
11月24日晚6点左右,火币全球站数据显示,比特币最高涨到了19099美元,距2万美元的历史新高仅5%的差距。比特币“一骑绝尘”主要源于机构投资者的追捧.
原文链接:Forkast 近期热点: ETH2.0即将在下周启动比特币暴涨,摩根大通CEO仍旧不买账稳定币ARTS,BELT和USDC席卷南美BitMex之后.
据《华尔街日报》报道,乔·拜登计划提名前美联储主席JanetYellen担任美国财政部长,JanetYellen是美联储历史上首位女性主席,若上任,她将成为美国历史上第一位女性财长.
过去一周,市值最高的加密货币比特币一度突破16000美元,市场极度看涨,然而这种趋势还能走多远? 加密货币 本周初比特币一度跌至15000美元附近,但是随后强势上涨多次突破16000美元.