因 “0x10” 地址的 Gas 消耗分歧产生的柏林硬分叉 Bug

以太坊 OpenEthereum 单客户端在区块 #12244294 处发生的 Bug 导致当时的以太坊网络停机,并在问题区块产生后无法与网络保持同步。那么造成这个事故的原因究竟是什么呢?

先看触发了这个事故的交易:

https://eth.tokenview.com/cn/tx/0x7006f38fa2e6654fae1a781aefc5885fe0cb8f778b1add10636eaf7e34279247

这是一笔合约调用交易,是从 KuCoin 交易所向其他地址分发ETH。

我们仔细分析一下合约调用过程:

Zcash正式推出4.0.0版本支持11月Canopy主网升级:9月3日,Zcash开发公司Electric Coin Company(ECC)官方发推宣布,Zcash已正式推出最新版本4.0.0。该版本支持主网Canopy升级。Canopy主网升级将于区块高度1046400进行,升级时间大约在11月中旬。与此同时,Canopy升级部署内容包括:

1.ZIP 207,资金流向部署;

2.ZIP 211,禁止向Sprout Value池添加新值;

3.ZIP 212,为交易Sapling输出提供注释纯文本格式,以允许接收人检查Diffie-Hellman密钥格式是否正确;

4.ZIP 214,Zcash开发基金的共识规则;

5.ZIP 215,明确定义和修改Ed25519验证规则。[2020/9/3]

在浏览器的“数据输入”栏展示的是合约调用的参数,第一行表示地址列表从“40”(16进制)字节,也就是 64 字节开始,图中第4行,第二行表示转移数额的列表从“1a0”(16进制)字节,也就是 416 字节开始,数据输入栏第15行。

转账是按照地址列表的顺序进行的,往每个地址转入的数额和转移数据的列表一一对应的。

现在我们开始遍历地址列表,看第三行的“10” (16进制),表示的是即将为接下来的 16 个地址转入 ETH。

按照图上顺序,当数到第11个地址的时候,发现值是“10”。这个值会被认为是地址列表中的第11个地址,然而事实上是表示转移数额的列表长度。那么按照第三行的指示,应该向 16 个地址转入,合约会把“0x10”当成地址继续执行转账操作,向地址“0x10”转入 0 个 ETH。

注意,“0x10”是EVM “特殊地址” 之一,它完全处在 EVM 的预编译合约列表内。它是一个由 EIP-2537 断言的预编译合约,是为 BLS 配对密码学程序而设的,但这个 EIP 还未部署到主网上。

那么在柏林硬分叉中给“0x10”发送 0 ETH 会造成什么呢?会造成 Gas 消耗产生分歧。

柏林硬分叉改变了 EVM 中 Gas 消耗量的计量方法。在 EIP-2929 实施后,如果在一笔交易中对同一个存储槽多次执行状态存储操作,第一次执行会消耗更多 Gas,后续执行的消耗会更少。

这就是OpenEthereum 在区块 #12244294 处发生 Bug 的根源:OpenEthereum包含了EVM已实现的预编译列表。所以OpenEthereum 会对该笔交易中访问了“0x10”的交易给gas 折扣。但网络的绝大部分活跃客户端都不是这样实现 EIP-2929 的,它们只会给访问了已激活预编译合约的交易提供 gas 折扣。

由此,OpenEthereum 客户端对该交易消耗了多少 Gas 的计算与网络中其他客户端发生了分歧。

这场由Gas消耗分歧引起的 OpenEthereum 单客户端停机,虽没有严重到导致重大的链分叉,但也提醒我们利用多客户端实现来提升节点稳定性。

不可否认,区块链技术仍然处于不断尝试不断前进的过程中,2021 年爆发的Defi和NFT也以前所未有的速度普及给更多的受众,Tokenview希望携手更多的开发者打造更好的区块链世界。

郑重声明: 本文版权归原作者所有, 转载文章仅为传播更多信息之目的, 如作者信息标记有误, 请第一时间联系我们修改或删除, 多谢。

链杂谈

瑞波币技术周刊|Eth1-Eth2合并开发者测试网Steklo完成1日测试

本周技术周刊包含以太坊、波卡、Cosmos、Filecoin等四个网络的技术类消息。 Eth1-Eth2合并开发者测试网Steklo发布,仅适用于今天 4月30日消息,Protolambda启动实验性质的Eth1-Eth2合并后测试网。目前网络上有7个客户端,虽然Steklo开发者网络非常脆弱,但这是测试合并的一大步。

比特币最新价格Coinbase上市半月发生了什么?

编者按:即便有少量的利空消息存在,Coinbase上市半月的表现仍较为理想。 Coinbase上市已有半月,作为加密货币交易所,它的表现与币市息息相关。刚上市不久,比特币即创下63000美元的新高,但两周后也一度跌破50000美元。 除了比特币价格的波动,Coinbase自身股价也在震荡下行。

Luna金色趋势丨BTC牛市结束了还是蓄势下一轮新高?

BTC 我们从之前比特币12500砸至9850,回撤21.85%,19500砸至16218,跌幅16.86%,42000跌至28800,跌幅31.75%,58350跌至43000,跌幅25.72%,这还不包括盘中插针在收回的情况,所以短线波动是非常剧烈的,目前这一波从64850调整跌幅25%左右,我们知道牛市进程不是一蹴而就,基本都采用震荡向上的走势。

[0:46ms0-0:484ms