以太坊交易所 以太坊交易所
Ctrl+D 以太坊交易所
ads
首頁 > BTC > Info

柏林硬分叉對 Gas 影響幾何?_NBS:nbs幣最新消息

Author:

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

柏林硬分叉已于 4 月 14 日在主網上線,引入了四份 EIP 。其中的兩份 (EIP-2929 和 EIP-2930)對交易的 gas 成本有影響。本文將解釋部分 gas 成本在柏林前是如何計算的,加入了 EIP-2929 后會如何變化,以及如何使用 EIP-2930 引入的訪問列表。

這篇文章很長,這是它的概要:

柏林硬分叉改變一些操作碼的 gas 成本。如果在一個 dapp 或一個智能合約里 gas 費的值是硬編碼的,它們可能會中止運行。如果這種情況發生了,且智能合約是不可更新的,消費者將需要用 EIP-2930 的訪問列表才能使用那部分的操作碼。

訪問列表可以用作減少少量的 gas 成本,但實際上它們在一些情況下是會增加總 gas 消耗量的。

geth 增加了一個叫 eth_createAccessList 的新 RPC方法,用以簡化訪問列表的創建。

EVM 執行的每個操作碼都有一筆相關的 gas 成本。它們大多數的成本是固定的:PUSH1 總是消耗 3 個單位的 gas,MUL 消耗 5 個,等等。其他一些是會變化的:比如 SHA3 的操作碼成本依賴于它的輸入大小。

我們主要討論操作碼 SLOAD 和 SSTORE,因為它們是最受柏林硬分叉影響的。我們以后會討論針對地址的操作碼,比如所有的 EXT* 和 CALL* ,因為它們的 gas 成本也改變了。

柏林前 SLOAD 的 gas 成本

以太坊開發者Tim Beiko解釋為何柏林升級沒有納入EIP-2537:以太坊開發者Tim Beiko解釋為何柏林升級沒有納入EIP-2537表示,其在柏林升級需要更多測試,團隊總體都同意,但是當我們討論將它包含在倫敦升級時,有人提出了一個我們應該使用的新庫,并可能修改gas成本,這需要更多的測試,因為它沒有削減gas。此外,它從一個非常好的擁有(預存款合約啟動以驗證存款)變成了“我們在分片之前需要這個”,因此緊迫性大大降低。[2021/6/8 23:21:36]

在沒有 EIP-2929 之前,SLOAD 的 gas 消耗很簡單:它總是消耗 800 gas。所以(目前)沒有什么可說的。

柏林前 SSTORE 的 gas 成本

在 gas 消耗方面,SSTORE 可能是最復雜的操作碼了,因為它的成本取決于像存儲 slot 的當前值、新值、以及它是否之前被修改過。我們僅對一些情況進行分析以獲得一個基本理解;如果你想了解更多,請閱讀文末的 EIP 鏈接。

如果存儲 slot 的值從0 變成 1 (或任何非 0 的值),gas 消耗量是 20000。

如果存儲 slot 的值從1 變成2 (或任何其他非 0 的值),gas 消耗量是 5000。

如果存儲 slot 的值從 1 (或任何非 0 的值) 變成 0,gas 消耗量也是 5000,但在交易的最后你會獲得 1 筆 gas 費返還。本文不會討論 gas 費返還,因為它們在柏林硬分叉中不受影響。

如果存儲 slot 的值在之前相同的交易中被修改了,往后所有 SSTORE 的 gas 消耗量都是 800。

以太坊官方建議節點運營商盡快升級到柏林兼容版本:金色財經報道,以太坊官方博客發布了柏林(Berlin)升級公告。公告稱,柏林(Berlin)已準備就緒,第一個將要升級的測試網Ropsten計劃于3月10日升級,主網計劃于4月14日發布。如果正在運行以太坊節點,對于測試網,應盡快將其升級到柏林兼容版本,對于主網,應在4月7日之前升級至柏林兼容版本。博客文章稱,以太坊節點運營商應該在他們想要參與的網絡硬分叉區塊之前升級其節點。由于區塊時間的可變性,建議在預期日期前幾天更新。[2021/3/9 18:26:38]

這部分的細節并不有趣,重要的是 SSTORE 很貴,而它的消耗取決于幾個因素。

EIP-2929 對上述所有操作碼的 gas 消耗都有影響。但在深入這些變化前,我們需要先談談這份 EIP 引入的一個重要概念:訪問過的地址 (accessed addresses)與訪問過的存儲密鑰 (accessed storage keys)。

如果一個地址或一個存儲密鑰在之前的交易中被“使用”過,那么它們就會被視為“訪問過的”。例如,當你 CALL(調用)一個其他合約,該合約的地址就會被標為“ accessed (訪問過的)”。同樣地,當你 SLOAD(加載)或 SSTORE(存儲)一些 slot 的時候,交易的其他部分也會被視為訪問過的。哪個操作碼執行它并不重要:如果一個 SLOAD 讀取了一個 slot,接下來的 SLOAD 和SSTORE 都會被視為訪問過的。

這里值得注意的是,存儲密鑰是“內置于“一些地址的。就如這份 EIP 所解釋:

以太坊客戶端Geth1.10.1正式啟用柏林硬分叉升級,主網將于4月14日升級:3月8日消息,以太坊客戶端Geth發布1.10.1版本,作為1.10版本的首個小版本更新,僅僅是為了加入了柏林硬分叉升級的內容,所有測試網和主網節點都需要至少更新至該版本才可以進行柏林硬分叉升級。

其中,測試網Ropsten將于3月10日(區塊高度9,812,189)開啟柏林硬分叉,測試網Goerli將于3月17日(區塊高度4,460,644)開啟,測試網Rinkeby將于3月24日(區塊高度8,290,928)開啟,以太坊主網將于4月14日(區塊高度12,244,000)開啟。[2021/3/8 18:25:32]

在執行交易時,維持一組 accessed_addresses: Set[Address] 和accessed_storage_keys: Set[Tuple[Address, Bytes32]]

也就是說,當我們說一個存儲 slot 被訪問了,我們實際上說的一對 (address, storageKey) 被訪問了。

接下來談談新的 gas 消耗。

柏林后的 SLOAD

在柏林硬分叉之前,SLOAD固定消耗 800 gas。現在,它取決于該存儲 slot 是否被訪問過。如果它沒有被訪問過,gas 消耗是 2100;如果被訪問過了,則是 100。因此,如果該 slot 是在訪問過的存儲密鑰列表里的,SLOAD 的 gas 消耗會少于 2000。

柏林后的 SSTORE

讓我們在 EIP-2929 語境下重溫前面的 SSTORE 例子:

以太坊柏林升級范圍或將包含5個提案,可能會提升部分指令的Gas成本:在以太坊開發者會議中,核心開發者針對以太坊下一次硬分叉升級(代號柏林)的升級范圍進行了討論,可能會包含的升級內容為EIP-2929、EIP-2930、EIP-2718、EIP-2565和EIP2315。其中比較爭議的部分為EIP-2929,該提案由Vitalik Buterin提出,提議增加首次存儲讀取和帳戶訪問的Gas成本,但該方案可能會影響部分老智能合約的執行。[2020/11/30 22:34:58]

如果存儲 slot 的值從0 變成 1 (或任何非 0 的值),gas 消耗量是:

如果存儲密鑰沒有被訪問過,22100

如果被訪問過了,20000

如果存儲 slot 的值從1 變成2 (或任何其他非 0 的值),gas 消耗量是:

如果存儲密鑰沒有被訪問過,5000

如果被訪問過了,2900

如果存儲 slot 的值從 1 (或任何非 0 的值) 變成 0,gas 消耗與上一種情況一樣,再加上返還。

如果存儲 slot 的值在之前相同的交易中被修改了,往后所有 SSTORE 的 gas 消耗量都是100。

如你所見,如果 SSTORE 正在修改的 slot 是之前被訪問過的,第一個SSTORE 消耗少于 2100 gas。

下表對上述的值進行了比較:

動態 | 俄亥俄州都柏林市正尋求個人身份區塊鏈實驗:據coindesk報道,美國俄亥俄州都柏林市一直在悄悄地尋求一項以個人身份為重點的區塊鏈實驗。該市上個月通過發布征求建議書(RFP)透露了其工作。如果該提案獲得通過,都柏林將成為該州最新探索區塊鏈技術在公共部門應用可能性的城市。根據征求建議書,該市宣布打算通過開發一個數據庫來測試區塊鏈,該數據庫將允許當地官員創建一個安全的私人系統以收集和存儲個人信息和偏好,并創建內部“價值令牌”。該市提出的一個用例將允許注冊用戶在網絡上提交投票并查看投票的匯總結果。[2018/9/14]

請注意,在最后一行沒有必要談論 slot 是否已經被訪問過,因為如果它之前就被寫入,那它就被訪問過了。

我們一開始提及的其他 EIP 就是 EIP-2930。這份 EIP 增加了一種新的交易類型,它可以在交易里加入一個訪問列表。這意味著你可以在交易執行開始前,事先聲明哪些地址和 slot 應被視為訪問過的。例如,一個未被訪問過的 slot 的一個 SLOAD 需要消耗 2100 gas,但如果該 slot 被加入到交易訪問列表里,同一個操作碼只需消耗 100 gas。

但如果已經被訪問過的地址或存儲密鑰會消耗更少 gas,這是否意味著我們可以把所有東西都添加到交易訪問列表來降低 gas 消耗了?棒!不用給 gas 費了! 然而,不盡然是這樣,因為你每次添加地址和存儲密鑰的時候還是需要支付 gas 費的。

我們來看一個例子。假如我們正在向合約 A 發送一筆交易,訪問列表可能如下:

如果我們發送一筆附有這個訪問列表的交易,使用 slot 0x0 的第一個操作碼是SLOAD,它消耗的是 100 而不是 2100 gas。這減少了 2000 gas。但每次把存儲密鑰添加到交易的訪問列表中都需要消耗 1900 gas。因此我們只省了100 gas。(如果訪問該 slot 的第一個操作碼是 SSTORE而不是 SLOAD,我們可以省 2100 gas,也就是說如果我們考慮的是存儲密鑰的消耗的話,我們總共節省 200 gas。 )

這是否代表只要我們使用交易訪問列表就能節省 gas?不是的,因為我們還需要支付添加地址到訪問列表 (即我們的例子中的 "<address of A>" ) 的 gas。

到目前為止,我們只討論了操作碼 SLOAD 和 SSTORE,但柏林升級后不是只有這些操作碼有變化。例如,操作碼 CALL 之前的固定消耗量是 700。但 EIP-2929 后,如果地址不在訪問列表里,它的消耗量變成了 2600,如果在,則是 100。還有,像訪問過的存儲密鑰,無論之前訪問的是什么操作碼 (例如,如果EXTCODESIZE 是第一次被調用,那么該操作碼將消耗 2600 gas,而往后任何使用同一個地址的 EXTCODESIZE、 CALL 還是STATICCALL都只消耗 100 gas)。

這是如何影響有訪問列表的交易的呢?例如,假如我們給合約 A 發送一筆交易,而該合約調用另一個合約 B,那么我們可以加入這樣一個列表:

我們將需要支付 2400 gas 以把這個訪問列表加入到交易里,但之后使用 B 地址的第一個操作碼只消耗 100 gas,而不是2600。因此,我們通過這樣做節省了 100 gas。如果 B 以某種方式使用它的存儲,且我們知道使用的是哪個密鑰,那么我們也可以把它們加入到訪問列表里,這樣可以為每個密鑰節省 100~200 gas (取決于你的第一個操作碼是 SLOAD 還是 SSTORE )。

但是為什么我們要談論另一個合約?我們正在調用的合約呢?為什么不對這個合約進行這些操作?

我們可以這樣做,但這樣不劃算,因為 EIP-2929 明確規定正在被調用的合約 (即tx.to) 地址會默認加入到 accessed_addresses 列表里。因此我們無須支付多余的 2400 gas。

讓我們再對之前的例子進行分析:

除非我們要加入多幾個存儲密鑰,否則這其實很浪費。如果我們預設 SLOAD 總是首先使用存儲密鑰,那么我們起碼需要24 個存儲密鑰能保本。

你可以想象一下,做分析與手動創建一個訪問列表并不那么有趣。幸運的是,其實有更好的方法。

Geth (從 1.10.2 版本開始 ) 加入了一個新的 eth_createAccessList RPC 方法,你可以用它來生成訪問列表。它的使用與 eth_estimateGas 相似,但它返回的不是 gas 估值,而是像下面這樣的結果:

也就是它給你該交易會用到的地址與存儲密鑰的列表,加上訪問列表被加入情況下所消耗的 gas。(像 eth_estimateGas,這是一個估值,當交易實際上被挖的時候,這個列表可能會改變。)但,這并不代表 gas 消耗量會低于在沒有訪問列表情況下發送同一筆交易所消耗的!

我想我們會隨著時間推移發現使用它的正確方法,但我猜的偽代碼如下:

值得一提的是,訪問列表的主要目的不在于使用 gas。如 EIP 所解釋:

減輕由 EIP-2929 引入的合約斷裂風險,因為交易可以提前指定交易計劃訪問的賬戶和存儲 slot 并提前支付;最終在實際執行中,操作碼 SLOAD 和 EXT*只消耗 100 gas:這個低 gas 消耗不僅可以防止由該 EIP 引起的斷裂,還可以“松開”任何因 EIP-1884 而受限的合約。

這意味著如果一個合約對執行某事務的成本做了假設,gas 成本的增加就可能使它停止運作。例如,一個合約調用另一個合約,像這樣someOtherContract.someFunction{gas: 34500}(),因為它假設someFunction 會準確消耗 34500 gas,這樣它會出問題。但如果你添加了一個合理的訪問列表,那么合約會再次運作。

如果你像自己去測試,復制這個代碼庫,里面由多個可以用 Hardhat 和 geth 執行的實例。在 README 查看說明。

參考文獻

EIP-2929 和 EIP-2930 是與本文相關的兩個柏林硬分叉 EIP。

EIP-2930 依賴于柏林硬分叉的另一部分: EIP-2718,它又叫類型交易。

EIP-2929 參考了很多 EIP-2200,因此如果你想深入了解 gas 成本,你可以從那里開始。

Tags:NBSBSPGASLOTnbs幣最新消息BSP幣Ontology GasPLOT價格

BTC
金色前哨 | Coinbase正式掛牌納斯達克 開盤價料為340美元_INB:OIN

金色財經報道,北京時間4月14日21時30分,Coinbase正式在美國納斯達克掛牌上市,股票代碼為COIN,暫未開放交易.

1900/1/1 0:00:00
猜想三年后Coinbase會變成什么樣?_COI:Bitcoin Private

作者?|?Jimmy ChangCoinbase日快樂!在寫這篇文章的時候,實際上是周二晚上--Coinbase將在納斯達克開盤的前一天晚上.

1900/1/1 0:00:00
4.16晚間行情:見頂了嗎 分歧中該如何抉擇?_TRUST:BTC

文章系金色財經專欄作者幣圈北冥供稿,發表言論僅代表其個人觀點,僅供學習交流!金色盤面不會主動提供任何交易指導,亦不會收取任何費用指導交易,請讀者仔細甄別防上當.

1900/1/1 0:00:00
Oasis隱私計算賽道的項目 有個擼毛的機會_SIS:ASI

2021年,隱私賽道進入黃金發展階段。Oasis Network是全球首個具有隱私保護功能和可拓展性的區塊鏈平臺,用于開放金融和負責任的數據經濟.

1900/1/1 0:00:00
金色趨勢丨BTC趨勢低吸機會來了_BTC:區塊鏈工程專業張雪峰

BTC 我們從之前比特幣12500砸至9850,回撤21.85%,19500砸至16218,跌幅16.86%,42000跌至28800,跌幅31.75%,58350跌至43000.

1900/1/1 0:00:00
Messari一季度報告:市場注意力從NFT轉移至DAO_HAUS:GAM

研究機構Messari對一季度Web3發展狀況進行回顧時指出,一季度開始時,NFT領域的新協議紛紛推出,引起了主流關注,特別是關于加密藝術和卡牌交易.

1900/1/1 0:00:00
ads