以太坊交易所 以太坊交易所
Ctrl+D 以太坊交易所
ads
首頁 > 萊特幣 > Info

EIP-3529:減少gas返還_STOR:TUTOR

Author:

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

簡單總結

移除SELFDESTRUCT的gas返還,減少SSTORE的gas返還到一個較低水平,使得返還的量仍然相當大,但不會像現在高到可以被利用的地步。

原因

最初引入SSTORE和SELFDESTRUCT的gas返還是為了鼓勵應用開發者寫應用時能踐行“良好的狀態衛生”,清理不再需要的存儲槽與合約。但是,結果證明這項技術帶來的效率遠低于預期,gas返還還帶來多項未預料到的有害后果:

gas返還導致GASToken的出現。GasToken有益于把gas空間從低費用階段轉移到高費用階段,但它也對網絡有壞處,尤其是加劇狀態大小膨脹(由于狀態槽被有效用作“電池”來積攢gas)和低效地堵塞區塊鏈gas使用。

gas返還加劇區塊大小變化。一個區塊實際消耗的gas量的理論最大值是接近名義上的gaslimit(因為返還會增加同一區塊里后面交易的gas空間,盡管返還的gas最多是該筆交易消耗gas的50%)。這一點不是致命的,但影響還是相當不好,特別是返還可以被用來維持比EIP-1559使用兩倍gaslimit更長的峰期。

Cobo安全團隊詳解Stargate漏洞:可能導致偽造的交易receipt通過MPT驗證:3月29日消息,Cobo安全團隊撰文對Stargate跨鏈橋底層協議LayerZero的安全漏洞進行分析,稱原始漏洞代碼在進行MPT 驗證時,沒有限制pointer 在proofBytes 長度內,這個漏洞有可能讓攻擊者偽造hashRoot,導致偽造的交易receipt 可以通過MPT 驗證。最終可造成的后果是,在預言機完全可信的前提下,Relayer 仍可以單方面通過偽造receipt 數據的方式來實現對跨鏈協議的攻擊。

值得注意的是,此次爆出漏洞的代碼是LayerZero協議中最核心的MPT交易驗證部分的代碼,是整個LayerZero及上層協議(例如Stargate)正常運作的基石。Cobo安全團隊還表示,LayerZero項目的關鍵合約目前大都還被EOA控制,沒有采用多簽機制或者時間鎖機制。如果這些特權EOA的私鑰一旦泄漏,也可能會導致所有上層協議的資產受到影響。[2022/3/29 14:24:49]

規范

參數

EthHub創始人 Sassano:EIP-3074、Altair升級等沒有得到足夠關注:5月18日消息,EthHub聯合創始人Anthony Sassano剛剛在推特表示,以太坊生態系統中讓我興奮但沒有得到足夠關注的事情:EIP-3074(用戶體驗的主要利好);以太坊信標鏈Altair升級;以太坊核心開發學徒計劃;DAOs啟動資助項目;Aztec L2隱私技術。[2021/5/18 22:14:22]

對于存在block.number>=FORK_BLOCK的區塊,需要作下列變更。

1.移除SELFDESTRUCT的返還

2.用SSTORE_RESET_GAS+ACCESS_LIST_STORAGE_KEY_COST(EIP-2929+EIP-2930合力下的4,800gas)取代SSTORE_CLEARS_SCHEDULE

3.把交易后的最大返還gas量減少到gas_used//NEW_MAX_REFUND_QUOTIENT

原理闡釋

EIP-2200引入了返還的三種情況:

聚幣Jubi將于3月19日啟動EIP溢價回購 JT回購價0.4052USDT:據官方消息,聚幣Jubi將于2021年3月19日(UTC+8)啟動3月EIP溢價回購,JT回購價為0.4052USDT。本月JT回購資金為208,759.3568 USDT,環比上月增長25.9%。JT場外預約回購將于3月19日15:00-20:00(UTC+8)限時開啟。

EIP是聚幣Jubi創新推出的溢價回購機制,每月JT回購價將定增35%,在新型通縮模型下,預計2021年6月EIP回購價格將達1 USDT(1 JT=1 USDT)。JT持幣時間久、日均持幣量越高的JT持有者將享受更多回購額度。[2021/3/16 18:49:40]

1.如果原始值是非零,新值是零,添加SSTORE_CLEARS_SCHEDULE的gas量到返還計算器

2.如果原始值是零,當前值是非零,新值為零,添加SSTORE_SET_GAS-SLOAD_GAS(當前是19,900)的gas量到返還計算器

3.如果原始值是非零,當前值是一個不一樣的非零值,新值等于原始值,添加SSTORE_RESET_GAS-SLOAD_GAS的gas到返還計算器

調查:多數以太坊挖礦項目不贊成EIP 1559提案:金色財經報道,一項新的調查顯示,參與以太坊EIP 1559提案社區調查的9個挖礦項目中,有8個對該建議持負面看法。其中有7個表示,如果被納入未來的硬分叉,他們將拒絕實施該EIP。該調查包括25個以太坊項目,大多數選擇匿名。根據ConsenSys產品經理和調查實施者Tim Beiko的說法,該調查缺乏交易所或錢包的參與。據悉,EIP 1559由V神于2018年首次提出,預計將使以太坊區塊鏈的收費市場更加可預測并緩解擁堵。[2020/10/9]

在這三種情況里,只有(1)會啟動gastoken且允許區塊在執行上消耗超過區塊gaslimit的gas。(2)不具有這個特點,因為要獲得19,900的gas返還,同一個存儲槽必須在之前從零改為非零,這需要消耗20,000gas。無法從一個存儲槽獲得gas并用它來編輯另一個存儲槽,意味著它不能被用作gastoken。另外,獲得返還需要恢復存儲的寫入和擴展,使得返還的gas不會增加客戶端處理區塊的工作量。(3)是相似的:只有當同一個存儲槽在之前已經消耗了5,000gas的時候才能獲得4,900gas返還。

動態 | 以太坊EIP 1559和EIP 1057將很可能出現延遲:據Coindesk報道,在周五以太坊核心開發者電話會議上,以太坊開發人員Rick Dudley稱,EIP 1559 為以太坊引入新的交易費模式,這是一個相當復雜的變化,目前在伊斯坦布爾升級前似乎不太可能完成。另外,EIP 1057提出了一種改進的PoW算法——ProgPoW,因為審計問題也將延遲。據悉,伊斯坦布爾升級計劃在10月中旬開始進行主網激活。[2019/5/25]

此EIP處理第一種情況。我們可以通過使用一個相似的“配對”變元來確定在何種條件下gastoken是不可用的(例如,你不可以在一個存儲槽里獲得比你的輸入更多的gas),將每一筆返還映射到同一筆交易的同一個存儲槽的前一筆支出。當一個存儲槽的原始值是非零值,如果它被改為0時,有兩個可能性:

1.這可能是存儲槽第一次被設置為零。在這種情況下,我們可以把這個時間與SSTORE_RESET_GAS+ACCESS_LIST_STORAGE_KEY_COST第一次讀取和編輯存儲槽的最小開銷進行配對。

2.這可能是存儲槽第二次被設置為零或被設置為零后的情況。在這種情況下,我們可以把這個事件與最近一次數值從零改為其他值,且SSTORE_CLEARS_SCHEDULE的gas從返還中被移除的變元進行配對。

對于第二次或之后的情況,SSTORE_CLEARS_SCHEDULE?的值是什么并不重要,因為那個gas大小的返還是與相同大小的清除返還相匹配的。這就只剩下第一種情況了。為了確保存儲槽上消耗的gas總量為正,我們需要SSTORE_CLEARS_SCHEDULE<=SSTORE_RESET_GAS+ACCESS_LIST_STORAGE_KEY_COST。因此,此EIP只把SSTORE_CLEARS_SCHEDULE減少到那兩項開銷的總和。

此EIP的另一個原因是,清除還未被讀取的數據(通常是“無用”數據)是不會有凈返還的,但清除被讀取過的數據(通常是“有用”數據)還繼續會有凈返還。

向后兼容性

返還當前僅在交易執行后應用,因此無法對執行中任何特定可用的調用框架造成影響。因此,清除它們將不會破壞任何代碼的執行,盡管它將使得一些應用變得經濟上不可行。

Gastoken會變得沒有價值。DeFi套利機器人今天經常不是使用已有的gastoken方案就是一個定制的,以減少鏈上的開銷,這得益于重寫它們的代碼以清除對那些不再有用的gas存儲機制的調用。

然而,完全保留在new=original=0!=current?里的返還,以及保留在其他nonzero->zero情況里的一些返還能確保一些接收(和值得)更好的gas開銷待遇的關鍵用例能持續獲益。例如,zero->nonzero->zero的存儲設置模式保持只需消耗大約100gas。這些模式包括兩個重要實例:

?反重入鎖(通常在一個子調用開始前從0變為1,當子調用結束時再變回0)

?ERC20授權與發送(當代幣轉移得到授權,"授權值"會從零變成非零,然后在代幣轉移過程中恢復到零)

對清除存儲激勵的影響

對之前關于移除返還的EIP(EIP-3298和EIP-3403)的批評是這些EIP完全消除了把一個值設為零的激勵,相當于鼓勵用戶不要完全清除一個存儲槽(即使他們想這么做),哪怕他們想再次使用該存儲槽的幾率是最小的。

舉一個例子,如果你有一個單位的ERC20代幣,且你要送出或賣出你的所有余額,你可以只給出0.999999個單位,把剩余的留下。如果你想在未來重新放入更多該種代幣到同一個賬戶,你僅需要為SSTORE支付5,000gas(2,100用于讀取+2,900用于非零變為非零的設置)而不是22,100(20,000用于零到非零值的設置)。今天,這部分的gas會被清除存儲獲得的15,000gas返還所抵消,因此,如果你有超過15000/17100=87.7%的把握會再使用這個存儲槽,你才會有動力這樣做;按照EIP3298或EIP3403的設定,抵消激勵這部分是不存在的,因此,如果你再次使用該存儲槽的可能性是大于0的,設為非零值會更好。

對于剩下的4,800gas返還,如果你覺得再次使用某個存儲槽的幾率大于4800/17100=28.1%,你才有保持該存儲槽為非零的動力。這并不是完美的,但它可能高于一般人在清除了他們的全部余額后在同一個地址重新獲得同一代幣的幾率。

gas返還的上限是所消耗gas量的1/5,這意味著這種返還僅夠用于增加處理一個區塊所需的存儲寫入操作量最多為25%,限制了利用這個機制進行以存儲寫入為重點的拒絕服務攻擊。

測試用例

EIP-2929的gas開銷

注意,“熱”和“冷”存儲槽之間是有區別的。這個表展示了EIP-2929下的值,假定所有變動過的存儲槽都已經是“熱”狀態(區別是一次性消耗2,100gas)。

減少了的返還后

如果通過把SSTORE_CLEARS_SCHEDULE從15,000變為4,800(以及去除selfdestruct的返還),減少了部分的返還,下面是是一個對比表。

安全考慮

返還對于事務執行時不可見的,因此這不會對事務執行邏輯產生任何影響。

如果我們不計算后來重置回零的零到非零的SSTORE,在一個區塊里執行的最大gas消耗量受到gaslimit的限制。不計算這些事可以的,因為如果這樣的SSTORE被重置了,存儲不會被擴展,客戶端實際上不需要調整默克爾樹;gas消耗是可以返還的,但客戶端對這些操作碼的處理通常也會被取消。如果new_value=original_value,客戶端應該保證不會進行存儲寫入;這是自以太坊創世以來的一次謹慎優化,但它現在變得更重要了。

來源|?eips.ethereum.org

作者|VitalikButerin&MartinSwende

Tags:GASSTOTORSTORTogashi InuYap StoneTUTORBlockchain Store Token

萊特幣
一圖讀懂|浙江省區塊鏈技術和產業發展“十四五”規劃_HEL:HAY

來源:浙江經信 原文件:省發展改革委省經信廳省委網信辦關于印發《浙江省區塊鏈技術和產業發展“十四五”規劃》的通知比特幣礦企TeraWulf今年1月挖出157枚比特幣.

1900/1/1 0:00:00
Boring DAO V3版本4大功能揭曉,去中心化的BTC跨鏈時代即將到來_RING:BOR

5月13日,BoringDAO在鏈節點直播間進行了V3版本發布會的直播。BoringDAO是第三代通用跨鏈協議,是聯接所有區塊鏈的去中心化資產橋.

1900/1/1 0:00:00
它來了它來了,AMM顛覆者Uniswap帶著王炸V3版本來了_UNI:uniswap幣排行

那么,期待已久的UniswapV3到底是什么呢?它和V2有何不同?當涉及到自動做市商領域時,這是否會改變游戲規則?它會直接在Layer2上啟動嗎?您將在本文中找到這些問題的答案.

1900/1/1 0:00:00
觀點丨DAO 如何通過Tresury來管理資金?_SUR:insur幣最新消息

作者?|?Ryanseanadams摘要:在過去的一年中,DAOTreasury總量有了很大的增長。最多的DAO協議具有超過140億美金的數字資產.

1900/1/1 0:00:00
比特幣不香了?以史為鑒:熱門品種輪轉后或將是曲終人散_加密貨幣:RES

來源:財聯社 作者:黃君芝 一家市場研究公司周一表示,比特幣和其他加密貨幣的價格今年大幅上漲,部分原因是華爾街和美國企業界越來越接受數字資產,但市場似乎正在醞釀一場更大的調整.

1900/1/1 0:00:00
金色DeFi日報 | dYdX Layer 2永續合約交易量達10億美元_DEF:DEFI

DeFi數據 1.DeFi總市值:1367.68億美元 市值前十幣種排名數據來源DeFiboxDeFi總市值數據來源:Coingecko2.過去24小時去中心化交易所的交易量:122.

1900/1/1 0:00:00
ads