概述
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 代碼)接受了它。問題的根源已經找到,相關客戶端已經在新的版本中修復了該問題:
以太坊倫敦升級完成后已銷毀500枚ETH:8月5日消息,今晚20時33分以太坊倫敦升級完成后,成功引入EIP-1559。據etherchain.org數據顯示,截止目前,已經銷毀超過500枚ETH。[2021/8/5 1:37:10]
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 日志
Ethermine礦池宣布將在倫敦升級后變更支付政策,100%而不是80%的MEV獎勵將轉發給礦工:官方消息,Ethermine礦池宣布,在區塊高度12,965,000進行倫敦升級后,將變更支付政策:100%而不是80%的MEV獎勵將轉發給礦工;現在也可以通過IP驗證啟動手動支付和更改閾值;最低支付門檻將降至0.01 ETH且無每月自動支付;礦工為所有以太坊主網支付交易支付的支付交易費,礦工可以設置他們愿意支付的最高gas價格。[2021/7/19 1:02:57]
eth_getBlock 輸出 (go-ethereum)
(注:所有時間已轉換成北京時間)。
2021 年 7月 21日
18 : 39:Ropsten 測試網上挖出區塊 10679537。
以太坊測試網Rinkeby已于區塊高度8897988處激活倫敦升級:以太坊測試網Rinkeby已于7月8日01:27:32在區塊高度8897988處激活倫敦升級。本次升級包括了改變以太坊1.0Gas費用市場的的EIP-1559以及將難度炸彈推遲至2021年12月1日等更新,測試網Rinkeby激活倫敦升級的下一步將是在以太坊主網部署倫敦升級,主網升級的最終時間將在7月9日舉行的以太坊核心開發人員會議上宣布。[2021/7/8 0:35:40]
21 : 53:OpenEthereum 開發者在 Ethereum R&D discord 的 #1559-dev 頻道發帖稱他們的節點卡在了區塊 10679538 處。
21 : 58:@smixx 稱他們的在 Ropsten 節點位于區塊 10680453。
22 : 36:Besu 確認他們的節點也拒絕了區塊 10679538。
以太坊倫敦升級已確定所有納入的EIP,共包括EIP-1559等5個EIP:以太坊開發者Tim Beiko發文概述以太坊倫敦升級。雖然目前還未確定各網絡的升級區塊,但已最終確定納入的所有EIP。根據升級規范,它們是:
EIP-1559:改變ETH 1.0鏈的費用市場;
EIP-3198:BASEFEE操作碼;
EIP-3529:減少退款;
EIP-3541:拒絕以0xEF字節開頭的新合約;
EIP-3554:難度炸彈延遲至2021年12月1日。
此前消息,對于以太坊測試網進行倫敦升級的時間,Ropsten定于區塊高度10399301(6月9日),Goerli定于區塊高度4979794(6月16日),Rinkeby定于區塊高度8813188(6月23日),主網仍定于7月14日進行升級,在第一個測試網成功分叉后,再確定主網客戶端升級區塊。[2021/6/14 23:35:11]
22 : 51:確認挖出區塊 10679538 的礦工是 go-ethereum節點。
以太坊確定將難度炸彈延遲到12月納入倫敦升級,已確定測試網升級區塊:5月14日,以太坊核心開發者進行電話會議,以太坊開發者Tim Beiko更新會議結果表示,會議的大部分時間都集中在解決倫敦升級的最終細節。倫敦升級覺得納入EIP-3541、EIP-3554。其中EIP-3541阻止部署以“ 0xEF”開頭的合約,為大規模EVM檢修(EIP-3540)奠定基礎;EIP-3554提議將難度炸彈延遲到12月。
此外,會議討論了測試網進行倫敦升級的時間,Ropsten定于區塊高度10399301(6月9日),Goerli定于區塊高度4979794(6月16日),Rinkeby定于區塊高度8813188(6月23日),主網仍定于7月14日進行升級,在第一個測試網成功分叉后,再確定主網客戶端升級區塊。[2021/5/15 22:06:17]
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 節點收到的區塊頭中的哈希與白名單中的不符,就會與之斷開連接。這就意味著,節點將排斥錯誤的鏈上的對等節點,只與較短(但是正確的)鏈上的對等節點連接。
Tags:NBSBSPETHETHEnbs幣未來價格BSPTethereal最美翻譯togetherbnb可以推到的有誰
非同質化代幣(NFT) 通常與奇怪的藝術品和高昂的拍賣價格有關。批評者稱NFT為泡沫。但NFT背后的基本技術及其爆炸性用例表明經濟蓬勃發展、游戲格局發生了轉變、全新的時尚和收藏品,以及個人表達的.
1900/1/1 0:00:00以太坊區塊鏈的下一次重大升級,即倫敦硬分叉升級,可能會在區塊高度12,965,000實施,預計時間為下個月四號,也就是8月4日.
1900/1/1 0:00:00上圖是the block最新發布的各大項目NFT物品銷售量統計圖。從這張圖中,我們可以得到以下啟示:AXS開啟了鏈游爆發的先河,鏈游將會成為未來NFT賽道增長新動能.
1900/1/1 0:00:00社交媒體的去中心化正成為一項長期的發展趨勢。過去20年,隨著互聯網的進步,中心化的社交媒體迅速發展,為用戶帶來了便捷快速的服務。但隨之而來的是隱私侵犯、內容控制等問題頻發.
1900/1/1 0:00:00摘要:本文是對Tim Roughgarden的這篇優秀研究論文的總結,概述了EIP-1559提案的內涵,重申了Roughgarden的 "十大要點".
1900/1/1 0:00:00實現 閃電網絡的白皮書是一份長而復雜的文件,包含許多技術含量很高的概念;在 2015 年,很少有人有時間和能力讀完并且理解這份文件.
1900/1/1 0:00:00