買比特幣 買比特幣
Ctrl+D 買比特幣
ads

以太坊:難度炸彈推遲:該如何決策?_BLOCK

Author:

Time:1900/1/1 0:00:00

本文是為預測 EIP 4345 的影響而作的練習。這個 EIP 提議在 2021 年 12 月推遲難度炸彈。我們的目標是看看我們是否能幫助確定應該何時推遲、應該推遲多少,好讓難度炸彈預計在 2022 年 5 月份再次爆炸。

有關這個主題,我之前已經寫過很多篇文章了:

有關難度計算的方法:It’s Not the Difficult(中文譯本)

有關如何推遲難度炸彈:A Method to Diffuse the Difficulty Bomb

一些更老的文章見 此處 和 此處

難度炸彈的計算兩部分組成:A 部分,用于調整難度、平抑出塊時間的波動;B 部分,即難度炸彈本體(詳細解釋見上述第一篇文章)。

A 部分的調整時逐塊發生的,保證出塊時間圍繞 13.5 秒波動。這部分的調整效果非常好,如果沒有難度炸彈的話,將使出塊時間幾乎保持恒定。我們感興趣的是 B 部分。

B 部分的炸彈是一個階躍函數,每隔 10 萬個區塊,數值就變作兩倍。在 “爆炸” 之前,大家都不會注意到它,然而一旦它開始爆炸,數值上升的速度會非常快(跟 2^n 一樣。

以太坊核心開發者:仍將繼續通過影子分叉尋找漏洞,難度炸彈實施方案仍未達成共識:金色財經消息,以太坊核心開發者Tim Beiko在Twitter上分享了The Merge會議的內容。本次會議顯示,之前進行的兩次影子分叉進行相對順利,沒有出現重大問題,但在測試網正式分叉前還將繼續通過影子分叉來尋找可能的漏洞。在MEV方面,會議討論的結果顯示,mev-boost未來會有一個額外的約束,區塊的構建者需要尊重驗證者選擇的Gas限制。最后,Tim Beiko表達了其對難度炸彈的看法,由于難度炸彈對礦工以及用戶體驗的影響較大,所以其認為針對難度炸彈的設置和啟用應該謹慎,客戶端團隊成員甚至支持移除難度炸彈。[2022/4/30 2:41:49]

炸彈的數值依賴于 fake_period(偽周期號,在等式中表示為 n_sub_p)。fake_period 的值則完全依賴于 fake_block (偽區塊號)的數值;這個數值又是由當前區塊的區塊號(real_block 數值)以及 offset(推遲量)決定的。

我只有自己一個人。我帶著日漸疲憊的心、使用公開可得的數據寫下這篇文章。我在這里所說的一切都是可以討論的,但我已不準備為此負任何責任。本文中的一切,請自己帶著懷疑和謹慎加以看待和使用。

我是一個工程師,不是一個數學家,所以我對實際數據的興趣,要比對數學預測的大。在下文中,我會預測數據將如何改變。我的預測基于上面的公式,但都只用到了簡單、直接的 Excel 表格。

以太坊確定將難度炸彈延遲到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]

我的討論基于三個簡單的觀察:

A 部分工作得非常好,使得出塊時間穩定在平均 13.3 的水平。

B 部分也工作得非常好,它是獨立于 A 部分的,并且只會提高區塊時間。

如果我們忽略炸彈部分,我們的預測會是保守的。

換句話來說,如果我們的預測忽略了炸彈的效果,我們預測的時間將會比實際時間 “提早” 一些。這樣的話,即使我們預測錯了,也會有額外的緩沖時間。

動態 | 以太坊開發者一致同意推遲難度炸彈:據trustnodes報道,以太坊開發者同意在伊斯坦布爾升級的幾周后,進行緊急硬分叉。在以太坊開發者和其他非開發參與者(如市場人員或礦工)的公開討論中,所有與會者都認為難度炸彈將被延遲。[2019/12/1]

第一個表格使用當前的區塊號(在撰文之時是 1339 1127),并按每塊 13.3 秒的時間推算出 1400 0000 區塊高度的時間:

看仔細一些,我們發現,自區塊號 1200 0000 以來,平均出塊時間一直在提高(盡管 8 月和 9 月有所下降)。當然,隨著炸彈的爆炸,平均出塊時間會增加得越來越快。

再次強調,為了保守一些,我們選擇 13.3 秒的出塊時間來預測未來區塊挖出的具體時間,并且,我們暫時忽略難度炸彈的效果。當難度炸彈爆炸時,平均出塊時間增加;所以,忽略難度炸彈的結果是我們預測的時間將早于實際挖出的時間。(按我們這個例子來看,就是區塊 1400 0000 將 “不早于” 2022 年 1 月 10 日挖出。)

我們考慮的第一個問題是,“何時應該分叉?”

動態 | 以太坊難度炸彈已啟動,供應下降出塊時間延長一秒:以太坊區塊鏈“難度炸彈”已經啟動,礦工的整體獎勵從每天約13500枚ETH降至12500枚ETH,隨著哈希率的增加,區塊獎勵也隨著區塊時間的增加而下降。出塊時間方面并沒有增加太多(大約一秒鐘),難度炸彈現已啟動。(trustnodes)[2019/11/21]

在我看來,答案完全取決于 fake_period 的數值。可以這么問:“我們應該在哪個區塊號分叉?1370 0050,1380 0050 還是 13900 0050?”(加上一個 50,確保沒有差一錯誤(off-by-one error) —— 為什么這很重要,則留給讀者當作練習 —— 公式的計算應該使用大于號呢,還是使用大于等于號呢?)

下面的表格展示了 fake_block 計算。

在這里我們并置了對每個區塊將挖出的具體時間的預測,以及偽區塊號的計算(用真區塊號減去偏移量,獲得偽區塊號,并推導出偽周期號)。

偽周期號正是我們感興趣的內容,因為難度炸彈的值完全取決于偽周期號的值。從我之前的工作來看,我們認為難度炸彈的效果會在偽周期號達到 41~42 之間的時候開始顯現,在此之前則不明顯。換言之,當偽周期號變成 41 時,B 部分的效果將壓過 A 部分的效果。

動態 | Eric Conner:以太坊難度炸彈已經爆炸 以太坊出塊時間已被延長:Ethhub 創始人 Eric Conner 在Twitter上表示,以太坊難度炸彈已經“爆炸”,以太坊出塊時間正在被難度炸彈逐步延長,平均挖礦時間已經從 14 秒升至 15.5 秒,并且會一直延長以太坊的出塊時間。以太坊君士坦丁堡升級中本身包含延遲難度炸彈的提案,但是由于該升級被發現存在漏洞,已經推遲到 6 周之后啟動。[2019/1/21]

我在這里不想解釋為什么難度炸彈的效果不會在偽周期號達到 41 之前顯現。我想說的只是,炸彈只會提高出塊的時間,而如果沒有炸彈的話,A 部分就會讓區塊時間保持在 13.3 秒左右。換句話來說,平均出塊之間會高于 13.3 秒,如果太低了(出塊速度太快了),A 部分就會調整難度,把出塊時間拉回來 —— 再直白一點 —— A 部分就是這么工作的。

給定上述分析,我建議在晚于 1380 0000 區塊的任意時間分叉。大概是 12 月中旬。我會建議以具體的區塊號(而不是日期)為目標,比如區塊號 1385 0000。“痛點”(也就是出塊時間明顯減慢的時候)會在大約 1 月中旬到來。所以這個目標也是有容錯空間的。

我們需要考慮的另一個問題是,“我們需要偏移多少偽區塊?”

如上所述,偏移量決定了偽區塊號,進而決定了偽周期號,進而決定了炸彈的值。所以,在下文中,我們會專注于偏移量,看看我們能學到什么。

首先,我們來看看這個 EIP 提議的偏移量。我們在此根據 13.3 秒的平均出塊時間生成一個簡單的圖表。同樣地,我們忽略炸彈的影響,因為我們知道炸彈只會提高區塊時間,因此讓相應區塊號的實際發生時間晚于我們的預測。我們將安排 “Arrow Glacier”(下一次分叉的代號)發生在 1380 0050 號區塊,并使用這個 EIP 提議的偏移量 1050 0000。

本圖似乎表明,如果我們(按照這個 EIP 的建議)設置 1050 0000 的偏移量,則難度炸彈最早將在 4 月中旬(也即偽周期號再次到達 41 的時候)開始爆炸。到 5 月中旬,區塊將開始顯著變慢(偽周期號到達 43)。

我們之前遇過的最大的偽周期號就是 43, 是在 “拜占庭” 分叉之前。出塊時間的增加顯著可見 —— 達到了數秒的級別。

為了消遣,我準備看看如果我們提早或推遲分叉的時間,會有什么影響。

下面的這張表顯示了估計的結果 —— 讓我有點意外 —— 分叉的時間對最終結果沒有影響。但是,我回想了一些,覺得這是有道理的。因為,唯一一個決定偽周期號的量就是偏移量。除了讓當次分叉之前出塊變得更慢,推遲分叉的時間對下一次難度炸彈爆炸的時間(即四五月間)沒有任何影響。

你可以從上面這張圖看出,無論我們早點還是晚點實施 “Arrow Glacier” 硬分叉,只要我們使用 1050 0000 的偏移量,那就對下一次難度炸彈爆炸的時機沒有任何影響。

這個問題取決于你想在 5 月的時候給以太坊核心開發者多大的壓力。如果你想給他們很大的壓力 —— 讓 5 月的時候整個世界都會抱怨以太坊出塊速度變慢 —— 那就把偏移量設得小一點。如果你只想輕輕地推他們一下 —— 類似于 “我們最好現在采取行動,不過也不是特別著急” —— 那就支持大一點的偏移量。

如果你使用了 1050 0000 的偏移量,你可能是在給他們很大的壓力。你可以預期,四月底就會看到出塊顯著變慢(慢上一秒的那種)。但是,難度炸彈的麻煩之處在于,一旦開始爆炸,就不會給人喘息之機。

從 “明顯(變慢)” 到 “非常顯著”,到 “令人煩躁”,再到 “搞什么鬼” 再到 “以太坊去死吧”,只需要 4 到 6 周時間。我不是瞎扯,因為每一個 10 萬區塊的周期都會越來越長(因為每過一個周期,炸彈數值就會翻倍,出塊時間會增加得非常快),而且只要開始爆炸,就會爆炸得越來越快。詳見我上面關于 “拜占庭” 分叉前爆炸情況的文章。難度炸彈是來得很慢,但爆炸之后可就是另一番景象了。

在最后一個表格中,我建議使用 1070 0000 的偏移量。我同樣建議在1380 0050 號區塊后分叉。這會讓我們現在有休息的時間,并讓預計下一次爆炸的時間推到 5 月中旬。這是保守估計,但也是現實的考量。

結論:需要設置大于 1050 0000 的偏移量。

決定你想給核心開發者多大的壓力。如果你想狠狠推他們一把,就把偏移量設為 1050 0000;如果你想放過自己,就請設置為 1070 0000。搖擺不定的,可以在這兩者間取一個值。

“何時” 激活分叉的決定對下次爆炸的時間沒有影響(也即,都左右不了炸彈會在 5 月份爆炸)。這個決定唯一影響的是 “Arrow Glacier” 硬分叉之前 出塊時間會拉長到多久。這是因為,只有偏移量會影響偽周期號,也只有偽周期號會影響難度炸彈的數值。

TrueBlocks 是完全用我們的個人資金支持的項目,少量獎金來自以太坊基金(2018)、Consensys 公司(2019)、Moloch DAO(2021)以及近期的 Filecoin/IPFS(2021)。

如果你喜歡本文,或者希望支持我們的工作,請看我們的 GitCoin 主頁:https://gitcoin.co/grants/184/trueblocks。請給下一輪匹配捐款。我們會從更大的匹配獎勵中獲得額外的利益。即使很小的數額也會產生很大的效果。

Tags:以太坊LOCBLOCBLOCK以太坊硬幣交易所交易時間LOCKPAYAra BlocksLBLOCK

幣安app下載
DOG:使用以太坊登錄:中心化身份提供商的替代方案_web3.0幣種怎么提現

?電子郵件/密碼登錄的時代即將結束。通常在登錄“web2”服務時,我們需要使用用戶名或電子郵件地址和密碼.

1900/1/1 0:00:00
OIN:Nervos Network架構師謝晗劍:區塊鏈抽象與演進_COIN

金色財經現場報道,10月26日,由萬向區塊鏈實驗室主辦的第七屆區塊鏈全球峰會在上海舉行,Nervos network 架構師謝晗劍在題為《區塊鏈抽象和演進》的分享中稱.

1900/1/1 0:00:00
區塊鏈:后疫情時代的腎上腺素 “元宇宙” 有哪些不可忽視的安全問題?_NBS

宇宙前面加個“元”,世界就在你眼前。要說最近兩個月最火的一大概念,那“元宇宙”必定排在最前面。首先是Facebook改名刷爆社交媒體,再到二級市場相關概念股前仆后繼上漲,這個平行于現實世界的虛擬.

1900/1/1 0:00:00
CEL:Elon Musk的Meme作為NFT以近2萬美元的價格出售_meme幣智能狗

科技公司首席執行官Elon Musk是一個著名的meme迷。事實上,有些人會稱他為模因領主,他在去年夏天的推文中就承認了這一點.

1900/1/1 0:00:00
加密貨幣:新聞周刊 |22家境內外機構參與多邊央行數字貨幣橋測試_數字貨幣詐騙案例虞城縣劉店鄉

金色周刊是金色財經推出的一檔每周區塊鏈行業總結欄目,內容涵蓋一周重點新聞、礦業信息、項目動態、技術進展等行業動態。本文是其中的新聞周刊,帶您一覽本周區塊鏈行業大事.

1900/1/1 0:00:00
THE:神秘FWB DAO:思考世界的下個版本_NFT

Friends With Benefits,直譯為“有好處的朋友們”。但如果美劇看的多,你一定會知道,這個詞其實主要指“炮友”。而它現在可能會被一個DAO賦予新的含義.

1900/1/1 0:00:00
ads