区块见闻 区块见闻
Ctrl+D收藏区块见闻
首页 > NEAR > 正文

伦敦升级 Ropsten 测试网事故回顾

作者:

时间:

概述

2021年 7 月 21 日,OpenEthereum 团队注意到他们在 Ropsten 上的节点卡在了区块 10679538 处。人们原以为这是 OpenEthereum 的问题。其实,问题真正出在 go-ethereum 实现检查 1559 交易发送方余额的方式上。一个无效交易(发送方余额只够支付交易实际使用的 gas,而非交易指定的 maxFeePerGas 总额)被打包进了区块。由于 Ropsten 矿工运行的都是 go-ethereum,这个区块随后又被其它 go-ethereum 矿工接受,但是被网络中的其它一些客户端拒绝了。具体来说,OpenEthereum 和 Besu 拒绝了这个交易/区块,Nethermind、go-ethereum 和 Erigon(这些客户端实现的部分代码来自 go-ethereum 代码)接受了它。问题的根源已经找到,相关客户端已经在新的版本中修复了该问题:

go-ethereum: v1.10.6, fix PR;

Erigon: v2021.07.04-alpha, fix PR;

Nethermind: v1.10.79, fix PR。

问题区块的信息

网络:Ropsten

区块编号:10679538

哈希值:0x1252a34c4f2b061adc609e909d958c02e1ac39043e2e60c0ec47e565e3f625f1

OpenEthereum debug 日志

eth_getBlock 输出 (go-ethereum)

国家知识产权局:已有1.6万件元宇宙商标申请,严打蹭热点等恶意注册:2月21日消息,随着“元宇宙”概念持续走热,包括腾讯、小红书、爱奇艺在内的许多企业都尝试着申请“元宇宙”相关商标,然而申请均遭到驳回。国家知识产权局表示,截至目前,在商标数据库中约有1.6万余件“元宇宙”“METAVERSE”相关商标申请。国家知识产权局依据《商标法》及其有关条例规定,依法对“元宇宙”“METAVERSE”相关商标注册申请予以审查。国家知识产权局还特别指出,坚决反对、严厉打击“蹭热点”和不以使用为目的囤积等商标恶意注册行为。相关市场主体在申请注册商标时,应符合《商标法》有关规定,遵守诚实信用原则,不得损害社会公共利益、扰乱商标注册秩序。 (澎湃新闻)[2022/2/21 10:06:21]

(注:所有时间已转换成北京时间)。

2021 年 7月 21日

18 : 39:Ropsten 测试网上挖出区块 10679537。

21 : 53:OpenEthereum 开发者在 Ethereum R&D discord 的 #1559-dev 频道发帖称他们的节点卡在了区块 10679538 处。

21 : 58:@smixx 称他们的在 Ropsten 节点位于区块 10680453。

22 : 36:Besu 确认他们的节点也拒绝了区块 10679538。

22 : 51:确认挖出区块 10679538 的矿工是 go-ethereum节点。

22 : 55:确认 go-ethereum 矿工仍继续在区块 10679538 上面挖矿。

22: 56:确认 Nethermind 也接受了区块10679538。

23 : 08:go-ethereum 已确认问题的根本原因。

23 : 43:go-ethereum 开启 pull request,提供候选修复方案。

23 : 46:Erigon 开启 pull request,提供候选修复方案。

2021年 7月22 日

00 : 01:更新后的 go-ethereum 和 Besu 矿工在 Ropsten 上重启(此时,错误的链已经挖到了区块 10680803)。

00 : 43:EthereumJS 确认与 go-ethereum、Erigon 和 Nethermind 存在同样的问题。

01 : 57:Nethermind 开启 pull request,提供候选修复方案。

10 : 22:修复后的版本挖出了区块 10680804。

22 : 54:go-ethereum 发布了修复后版本 v1.10.6。

~23 : 00:Nethermind 发布了修复后版本 v1.10.79。

2021 年 7 月 23日

~00 : 00:Erigon 发布了修复后版本 v2021.07.04-alpha。

提高规范中断言(assertion)的清晰度

该提交新增了关于 EIP 1559 类型交易有效性的断言。具体来说,在第 217 行代码新增了以下断言:

另外还要注意的是,在前几行代码(第 207 行)中,sender.balance 被修改成了减去交易量之后的部分(sender.balance -= transaction.amount)。这个参数引发了混乱,因为一些客户端团队在检查第 217 行定义的断言时使用的是全部 sender.balance(即,没有减去transactiion.amount 的发送者地址余额),而非更新后的值。

@holiman 关于 go-ethereum 恢复的说明:

节点同步时跟随错误的链

假设你正在运行 geth,并处于同步中。区块 X 上发生了分叉。你的节点跟随了总难度较高的错误的链。在区块 Z,你停止了节点并将其更新至修复后版本。

问题描述:节点依然在 “错误” 的链上。

解决方案:执行 debug.setHead{X-1) 回到分叉发生之前。这会将节点倒回区块 X 之前的某个状态,不一定是区块 X-1 的状态,因为 geth 不一定有区块 X-1 的完整状态,但是会有其它某个区块的完整状态。通常情况下,geth 大约每隔 1 万个区块(1 小时)和/或宕机时会将状态刷到磁盘。如果 geth 在 gcmode=archive 下运行,就会将每个区块都刷到磁盘。

当错误的链总难度较高时进行同步

假设你正在同步一个 geth 节点,区块 X 上发生了分叉。由于分叉已经发生了,再加上错误的链总难度更高,你很可能会同步错误的链,pivot 区块是 X+M。在这种情况下,由于你没有区块 X+M 之前的状态,无法执行 debug.setHead 来解决这个问题。

这种情况需要重新同步。但是,你需要防止 geth 同步错误的那条分叉链。这可以通过 whitelist 命令行参数实现。

因此,你需要执行 geth --whitelist 123123=0x2342fafa9af9af9af9af9af9。

所谓的白名单,就是一个 geth 节点在与另一个对等节点连接时会向对方请求区块 123123 的数据。如果该 geth 节点收到的区块头中的哈希与白名单中的不符,就会与之断开连接。这就意味着,节点将排斥错误的链上的对等节点,只与较短(但是正确的)链上的对等节点连接。

标签:BSPNBSETHETHEBSP价格NBS币ethnology和ethnographyEthereal网名

NEAR热门资讯
金色观察 | 以太坊开发者修复EIP-1559漏洞 让伦敦升级顺利进行

概要 1.以太坊开发者清除以太坊测试网客户端漏洞。 2.伦敦硬分叉仍于8月4日进行部署。 以太坊开发者正一直在努力解决测试网代码和客户端问题,让下一个以太坊网络重大升级顺利进行。 7月21日,在“伦敦测试网回顾”中,以太坊首席开发者Tim Beiko详细介绍了即将到来的升级测试阶段最新进展。

金色观察 | 第一个将BTC作为法币的国家

上个月,萨尔瓦多成为世界上第一个将BTC作为法定货币的国家。 虽然看到外国政府接受这种货币我并不感到惊讶,这只是时间问题,而不仅仅是一个假设,但对加密行业来说,这仍然是一个相当了不起的时刻。正因如此,本文将更深入地探究一下该国目前现状及对未来发展道路。

智能合约体系与功能服务的融合和革新?NA生态最大程度打造开发者喜爱度最高的公链

变幻莫测的区块链其中蕴藏着数以万亿计的潜在市场,随着进程的不断突破,区块链技术围绕公链展开的数字竞赛已成为开发者们必将遇到的核心关键。

国有银行数交会力推数字人民币

7月22至25日,2021中国国际数字和软件服务交易会在大连举行。中国工商银行、中国建设银行、中国农业银行等国有银行组团现身参展,组成数字人民币展区,通过各种场景和技术手段展示推广数字人民币的应用。

DeFi 的盈利能力是否优于 ETH 投资?

Glassnode的分析师评估了主动和被动DeFi策略的风险调整回报与现货买入和持有ETH的情况。 随着DeFi的爆炸式增长,涌现了无数新的项目、工具和全新的创造新金融产品的方式。创新带来了增长的挑战和风险,而 DeFi 工具,顾名思义,通常需要更多的关注和积极的参与。这与许多加密货币投资者习惯的“设置并忘记它”的方法完全不同。

Celer cBridge 主网上线:无缝桥接跨链和跨层流动性

Celer cBridge v1.0版本今天正式主网上线!用户可以立即使用cBridge在Ethereum、Arbitrum、Binance Smart Chain以及Polygon进行高速低成本跨链和跨层转账。 cBridge将会在短期内支持更多的layer2和layer1区块链的跨链转账。