比特幣價格 比特幣價格
Ctrl+D 比特幣價格
ads
首頁 > LTC > Info

GAS:以太坊今日將完成柏林硬分叉升級,這些知識點你需要了解_TOR

Author:

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

在北京時間4月15日下午18:00左右,以太坊的柏林硬分叉升級將會發生,這次升級將納入4個新的EIP改進提案,而其中兩個將會影響交易的gas成本計算。

本文解釋了在這次硬分叉升級前后的gas成本計算,這將如何隨EIP-2929而發生改變,以及如何使用EIP-2930引入的訪問列表功能,原文作者是NomicLabs軟件開發者FrancoVictorio。

注:文章篇幅較長,以下是其中的一些要點:

柏林硬分叉改變了一些opcode操作碼的gas成本。如果你在dapp或智能合約中有一個硬編碼的gas值,它們可能會停止工作。如果發生這種情況,并且智能合約是不可升級的,則用戶將需要使用訪問列表來啟用它。

訪問列表可用于稍稍降低gas成本,但在某些情況下,它們實際上會增加gas消耗總量。

geth包含了一個新的RPC方法來簡化訪問列表的創建。

柏林硬分叉前的gas成本

EVM執行的每個opcode操作碼都有一個相關的gas成本。對于大多數操作碼而言,這個成本是固定的:PUSH1總是消耗3個單位的gas,MUL則消耗5個單位的gas,等等。而對于其他操作碼來說,它是可變的:例如,SHA3操作碼的成本取決于其輸入的大小。

以太坊客戶端Prysm為Shapella升級發布V4.0.0版本:3月31日消息,以太坊客戶端Prysm為Shapella升級發布V4.0.0版本。該版本對所有主網信標節點和驗證器都是強制性的,必須于4月12日之前升級。[2023/3/31 13:37:34]

我們將重點討論SLOAD和SSTORE操作碼,因為它們是受柏林硬分叉影響最大的操作碼。我們稍后將討論那些以地址為目標的操作碼,就像所有的EXT*和CALL*操作碼,因為它們的gas成本也會發生變化。

柏林硬分叉之前的SLOAD

如果沒有EIP-2929,SLOAD的成本很簡單:它總是會消耗800gas。

柏林硬分叉之前的SSTORE

就gas而言,SSTORE可能是最復雜的操作碼,因為它的成本取決于存儲slot的當前值、新值以及它是否以前被修改過。我們將只分析一些場景以獲得基本的理解。如果你想了解更多,請閱讀本文末尾鏈接的eip。

如果slot的的值從0更改為1,則成本為20000;

如果slot的的值從1更改為2,則成本為5000;

如果slot的的值從1更改為0,則成本也為5000,但在交易結束時你將獲得gas退款。這篇文章中,我們不會詳細討論退款,因為它們不受柏林硬分叉的影響;

如果以前在同一事務中修改了該值,則所有后續sstore的成本為800;

以太坊的主網已完成第10次影子分叉,比預期早26小時:金色財經報道,以太坊的第十個影子分叉于昨天生效,比預期早了26小時,此時終端總難度 (TTD)在區塊高度15217902被覆蓋為 54,892,065,290,522,348,390,492 。\u2028影子分叉使該項目離以太坊 9 月份的主網升級更近了一步。第三次也是最后一次測試網合并,Goerli,預計將于 8 月 10 日發生。\u2028以太坊 DevOps 工程師Parithosh Jayanthi稱,這個影子分叉將測試與 Goerli 合并中將使用的版本近似的版本。至于為什么它比預期更早發生,Jayanthi稱是哈希率發生了明顯的變化,這可能會加快這一進程。這不會是最后一個主網影子分叉,以太坊將繼續運行主網影子分叉,直到合并。(Coindesk)[2022/7/27 2:41:39]

這里的細節有些枯燥,重要的一點是,SSTORE是非常昂貴的,其成本取決于幾個因素。

實施EIP-2929之后的gas成本

EIP-2929改變了所有這些值,但在此之前,我們需要先談談這個EIP引入的一個重要概念:已訪問地址和已訪問存儲密鑰。

如果地址或存儲密鑰以前在交易期間被“使用”,則該地址或存儲密鑰就被視為已訪問。例如,當你調用另一個合約時,該合約的地址會被標記為已訪問。類似地,當你SLOAD或SSTORE某些slot時,它將被視為在交易的其余部分已被訪問。不管是哪個操作碼做的:如果一個SLOAD讀取了一個slot,那么它將被認為對接下來的SLOAD以及SSTORE都是已訪問的。

多簽錢包Gnosis Safe上線以太坊二層解決方案Arbitrum:10月13日消息,以太坊二層解決方案 Arbitrum宣布多簽錢包Gnosis Safe 在 Arbitrum One上線。Gnosis Safe目前支持以太坊主網、xDai、Polygon、幣安智能鏈(BSC)、Energy Web Chain以及測試網Rinkeby和Volta。[2021/10/13 20:25:26]

這里需要注意的一點是,存儲密鑰位于某個地址的“內部”。正如EIP所解釋的:

“執行事務時,維護一組accessed_addresses:Set和accessed_storage_keys:Set]”

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

話雖如此,我們還是來談談新的gas成本吧。

柏林硬分叉之后的SLOAD

在柏林硬分叉之前,SLOAD的固定成本是800gas,現在,這取決于是否已訪問了存儲slot。如果未訪問,則成本為2100gas,如果已訪問,則成本為100gas。因此,如果slot在已訪問的存儲密鑰列表中,則一次SLOAD的成本會降低2000gas。

柏林硬分叉之后的SSTORE

讓我們在部署EIP-2929的環境下回顧一下之前的SSTORE示例:

截至目前以太坊2.0測試網Medalla參與率為61.51%:Beaconscan數據顯示,截至目前,以太坊2.0多客戶端測試網Medalla中,主動投票的驗證者數量與總驗證者數量的比值為61.51%。注,該比值是衡量網絡健康度的一個指標。在以太坊2.0中,驗證者的職責之一是提交attestation,可以理解為投票。驗證者投票的內容之一為對epoch進行投票(為CasperFFG共識算法運行的過程),以終局化epoch。得到超過2/3的驗證者支持的epoch會被終局化,此后再也不能改動。[2020/8/20]

如果slot的值從0更改為1,則成本為:22100,20000;

如果slot的值從1更改為2,則成本為:5000,2900;

如果slot的值從1更改為0,則成本與上一項相同,然后加上退款;

如果以前在同一交易中修改了該值,則所有后續SSTORE的成本為100;

如你所見,如果要修改的slot以前被訪問過,那么第一次SSTORE的成本將降低2100gas。

下面的表總結了目前為止所有改變的值:

請注意,在最后一行中,談論是否訪問了slot是沒有意義的,因為如果它以前被寫入過,則表明其也被訪問過。

動態 | Telegram“搬磚套利”詐騙,單筆被騙數額最高達2000枚以太坊,價值約400萬人民幣:據CoinHunter.io監測,北京時間6月18日12:42:28,又雙叒叕有用戶遭遇Telegram\"搬磚套利\"詐騙。不法分子謊稱可以1:140的比例以ETH兌換HT,誘騙“小白”用戶將ETH轉入詐騙者0x7C4C3B賬戶中用以兌換虛假HT(虛假HT合約地址:0x6f3428960aa5b42f20205387d7473a33e7290bd0)。截至報道時騙局仍在持續運轉,已有多名用戶受騙,該詐騙地址金額累計高達2192個ETH,單一用戶最高被騙取1968.35個ETH,價值約400萬人民幣。目前,該詐騙者已經資金轉移至開頭0xEAe1Ec的新地址。如有用戶遭遇此類詐騙事件,請及時聯系CoinHunter平臺。[2019/6/24]

EIP-2930

我們在文章開頭提到的另一個EIP就是EIP-2930,這個改進提案添加了一種新類型的事務,該事務可以在事務負載中包括訪問列表。這意味著你可以在事務開始執行之前預先聲明哪些地址和slot應被視為是已訪問的。例如,一個未訪問slot的SLOAD成本為2100,但是如果該slot包含在事務的訪問列表中,則相同的操作碼成本就為100。

但是,如果當地址或存儲密鑰已被訪問時,gas成本變更低了,這是否意味著我們可以將所有內容添加到事務的訪問列表中并降低gas成本呢?不完全是這樣,因為你還需要為添加的每個地址和每個存儲密鑰支付gas。

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

如果我們用這個訪問列表發送了一筆交易,并且第一個使用0x0slot的操作碼是SLOAD,則它將花費100gas,這就降低了2000gas的消耗量。但事務訪問列表中包含的每個存儲密鑰的成本為1900gas,所以我們只省了100gas。

這是否意味著我們在使用帶有訪問列表的交易時總是能節省gas消耗?并非如此,因為我們還要為訪問列表中的地址支付gas成本

已訪問地址

以上,我們只討論了SLOAD和SSTORE操作碼,但這些并不是柏林硬分叉之后唯一改變的操作碼。例如,原先調用操作碼的固定成本為700gas。但是在實施EIP-2929之后,如果地址不在訪問列表中,則開銷就是2600gas,但如果是在已訪問列表中,則開銷就是100gas。而且,與已訪問存儲密鑰一樣,之前訪問該地址的操作碼并不重要。

這是如何受到訪問列表交易的影響的?例如,如果我們將一筆交易發送至合約A,而該合約調用另一個合約B,那么我們可以包含如下訪問列表:

我們必須支付2400gas的費用才能將這個訪問列表包含在交易中,但是第一個使用B地址的操作碼將花費100gas。所以我們這樣做就節省了100gas,如果B以某種方式使用它的存儲,并且我們知道它將使用哪些密鑰,那么我們還可以將它們包括在訪問列表中,并為每個密鑰節省100/200的gas。

但我們為什么要談另一個合約呢?我們調用的合約怎么了?我們為什么不這樣做?

我們可以這樣做,但這是不值得的,因為EIP-2929指定了被調用的合約地址總是包含在accessed_addresses列表中,因此這只會白白浪費2400gas。

讓我們再次分析上一節的示例:

這實際上是浪費,除非我們包含多個存儲密鑰。如果我們假設一個SLOAD總是首先使用一個存儲密鑰,那么我們至少需要24個存儲密鑰才能實現收支平衡。

顯然,分析并創建這樣的一個訪問列表是沒有意義的。幸運的是,我們有更好的方法。

eth_createAccessListRPC方法

Geth包含了一個新的eth\ucreateAccessListRPC方法,其可以用來生成訪問列表。它的用法類似于eth_estimateGas,但它不是用于估算gas,而是返回如下內容:

也就是說,它為你提供了該交易將使用的地址和存儲密鑰的列表,以及如果包含訪問列表,則會消耗的gas。

我想,隨著時間的推移,我們會發現執行此操作的正確方法是什么,而我的偽代碼猜測是:

激活合約

必須要指出的是,訪問列表的主要目的不是使用gas,正如EIP所解釋的:

“EIP-2929所引入的是減輕合約破壞風險,因為交易可預先指定和支付交易計劃訪問的帳戶和存儲slot。因此,在實際執行中,SLOAD和EXT*操作碼只需要100gas,這已經足夠低了,它不僅可防止因該EIP而導致的破壞,還可以“激活”由于EIP1884而卡住的任何合約。”

這意味著,如果一個合約對執行某些操作的成本做出假設,那么gas成本的增加可能會導致它無法工作。例如,一個合約調用另一個合約因為它假設某個函數正好使用34500gas,那么它就會中斷,但如果在事務中包含適當的訪問列表,那么合約將再次工作。

如果你想自己測試這些EIP,你可以復制這個repo,它有幾個可使用Hardhat和geth執行的示例。有關說明,請查看README文件。

相關資料:

1、EIP-2929?和EIP-2930?

2、EIP-2930依賴于柏林硬分叉的另一組成部分:EIP-2718?;

3、EIP-2929引用了大量EIP-2200?的內容,所以如果你想更深入地了解gas成本,你應該從EIP-2200開始;

4、有關比較gas使用量變化的更復雜示例?;

Tags:GASSLOTLOTTOREthereum Gas LimitSLOT價格ZLOT幣TORC幣

LTC
DEFI:DeFi新玩法 | 一文了解Ethport如何降低以太坊DeFi操作成本_RIN

注:原文作者是Loopring首席架構師BrechtDevos,在這篇文章中,他闡述了能讓用戶在Layer2網絡直接與Layer1應用進行交互的Ethport設計.

1900/1/1 0:00:00
加密貨幣:加密貨幣IPO:Coinbase之后 下一個上市的是誰?_美國加密貨幣

Coinbase的成功上市是加密貨幣行業的一個里程碑,這標志著第一家完全受監管的加密貨幣公司成為美國上市公司.

1900/1/1 0:00:00
CHI:金色觀察丨當我們談論Chia時 我們在談論什么_加密貨幣有哪幾種形態

金色財經區塊鏈4月16日訊?成立于2017年8月的Chia旨在開發一個能夠優化區塊鏈和智能交易的平臺.

1900/1/1 0:00:00
OTC:案例評析:幣圈OTC與幫助信息網絡犯罪活動罪_DAO

案例評析 幣圈的朋友肯定會疑惑,虛擬貨幣OTC交易為何會與幫助信息網絡犯罪活動罪扯上關系?團隊小伙伴梳理了相關的裁判案例,通過“以案釋法”的方式詳細為大家解析了二者之間的關系.

1900/1/1 0:00:00
比特幣:觀點:中國在全球數字貨幣賽道上具有先發優勢_XRP

來源:21世紀經濟報道 作者:孫立堅 日前,包括土耳其、印度等在內的多個國家金融監管部門相繼頒布了嚴格的加密數字資產監管措施,市場還有消息稱美國財政部將指控數家金融機構使用加密貨幣洗錢.

1900/1/1 0:00:00
COIN:一文盤點:在Coinbase之后還有哪些加密貨幣企業將上市_加密貨幣

本文來源:PANews,作者:Jordan4月14日,Coinbase如愿登陸納斯達克,首日以328美元收盤,此前250美元的參考價格高出31%.

1900/1/1 0:00:00
ads