買以太坊 買以太坊
Ctrl+D 買以太坊
ads

KEI:觀點:以太坊狀態規模管理諸提議(上)_加密貨幣

Author:

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

以太坊協議所面臨的一個最為長久且尚未解決的挑戰,就是由于狀態數據規模不斷增長而帶來的問題。以太坊區塊鏈上的許多操作都會給以太坊添加狀態內容,而所有全節點都必須存儲全量的狀態數據,這樣才能驗證新區塊以及制造新區塊。這些操作只需事務的發送者一次性繳交按gas用量來計量的手續費,但會給整個網絡造成永久的持續性成本,因為節點需要存儲這些新數據。

這是系統設計中的一個顯著的失衡,可能會讓以太坊系統變得越來越難用,因為狀態中充斥著不再有用處的“垃圾數據”。本文的目的是詳細解釋問題產生的根源,以及一些解決該問題的方法。如果我們能實現某個解決方案,這將為安全地大幅提高區塊Gas上限鋪平道路。

本文所論述的研究領域仍在推進中,隨時有可能出現更新、更好的想法和更優雅的權衡。

引言:問題出在哪?

“狀態”指的是節點若想處理新產生的區塊和事務就必須存有的信息。狀態與“歷史”完全不同,后者是關于過去時間的信息,節點可以保存這些信息以便日后重新廣播或歸檔,但并不是處理區塊鏈所必需的。

觀點:加密貨幣已經準備好反彈:金色財經報道,比特幣基金管理公司Pantera Capital創始人Dan Morehead表示,比特幣、以太坊、XRP和更廣泛的加密貨幣已經準備好反彈。[2023/7/19 11:04:26]

在以太坊協議中,狀態信息包括:

賬戶的ETH余額和nonce

智能合約的代碼

智能合約的存儲項

與共識機制相關的數據

歷史信息則由舊的區塊和收據組成。EVM中沒有操作碼可以讓你訪問舊區塊、舊事務和內容和收據輸出,所以節點丟棄這些數據也仍然能驗證新區塊,所以這些是歷史信息。

上述狀態信息列表中的最后一項——共識機制相關數據——在設計上已經精心限制了其規模,因此我們不太需要為此困擾。但前面三項,就令人頭大了。這三類狀態信息的規模會隨著時間推移而不斷增大,因為不斷會有新用戶加入網絡,他們會創建新的賬戶、新的合約,還會加入合約、收到token什么的。

觀點:國會必須使加密貨幣市場結構的監管更加清晰:金色財經報道,今天在眾議院農業委員會和眾議院金融服務委員會的數字資產小組委員會的聯合聽證會上,小組委員會繼續討論國會議員French Hill所說的“不可能的情況,即相同的公司受到證券交易委員會(SEC)和商品期貨交易委員會(CFTC)的競爭執法行動,將企業家、開發商和就業創造者推向海外。”

CMFA的政策分析師Jack Solowev與CMFA金融監管研究主任Jennifer Schulp表示,“美國向那些致力于下一代全球金融基礎設施的人關閉大門顯然是不明智的。國會必須使加密貨幣市場結構的監管更加清晰,定義加密證券、加密商品和交易所(包括中心化和去中心化)的界限和適當的法律待遇。”

據此前消息,在2023年共識會議上,參議員Cynthia Lummis和國會議員Patrick McHenry表達了他們制定立法以闡明美國加密貨幣市場結構的目標,眾議院預計將在未來兩個月內提出提案。[2023/5/11 14:55:40]

難辦的是,許多狀態用過之后就會靜靜地躺在那里;一旦某個用戶停用某個應用之后,就會產生一些“垃圾狀態”——不會再派上用場,但會永遠存在那里。

觀點:全球投資業務中的1%資金將被配置到比特幣上:華爾街金融分析師、比特幣支持者Max Keizer對沃倫·巴菲特最近決定將其基金從全球主要銀行的股份中撤出,并押注巴里克金礦公司(Barrick Gold mining)的股票發表了評論,稱巴菲特對黃金和銀行的看法是錯誤的,更重要的是,他批評比特幣很可能是錯誤的。Max Keiser認為,隨著巴菲特進入黃金市場,全球投資業務可能會將5%的資金押在黃金上。這也讓Keiser相信,大約1%的資金(約1萬億美元)將被配置到比特幣上。(U.Today)[2020/8/15]

理論上,用戶可以做到“垃圾不落地”。用戶可以僅發布帶有SELFDESTRUCT條件的合約,等他們再也用不上這個合約的時候,就調用這個操作碼移除這個合約、清空其token余額;他們還可以使用智能合約錢包,通過一個已有的外部持有賬戶來發送交易,而無需生成一個新的EOA。

聲音 | 觀點:丹斯克銀行愛沙尼亞分行涉嫌洗錢2230億美元 遠高于數字貨幣用戶的洗錢金額:丹麥金融機構丹斯克銀行(Danske Bank)卷入了與愛沙尼亞分行有關的大規模洗錢丑聞,據稱該分行在8年內洗錢2230億美元。根據本周披露追溯至2012年的文件,丹斯克銀行的愛沙尼亞分行讓一批俄羅斯精選客戶將他們的資金轉換成金條,以幫助隱藏資金;轉移的黃金數量未知。該洗錢丑聞被稱為 “歐洲有史以來最大丑聞”,愛沙尼亞分行的洗錢資金來自俄羅斯、拉脫維亞、塞浦路斯、英國、中國、瑞士和土耳其。 Bitcoin.com文章指出,丹斯克銀行的丑聞表明,雖然政府和稅務機構正在打擊數字貨幣用戶可能正在洗錢的少量資金,但世界上最知名的銀行也是最大的洗錢者。世界領先的銀行每年幫助洗錢超過2萬億美元,并被處以一小部分罰款。銀行家沒有被監禁,銀行和政客被允許侵入普通人的日常金融活動。[2019/11/11]

但是在實踐中,這樣的激勵非常少,而適當的狀態清理的技術復雜性又太大了。在許多合約中,給任何人賦予這樣調用SELFDESTRUCT的權限都是不合適的,而且,也會給用戶體驗和代碼上也會增加很多復雜性。實際上,由于SELFDESTRUCT用處極其有限而副作用極大,我更傾向于永遠移除這個操作碼。如果我們真想控制狀態數據的規模,我需要的是一個網絡中的節點可以默認丟棄不再被使用的“垃圾狀態”的方法。

聲音 | 李笑來會客錄音主要觀點:不要盲?的相信“價值投資”:7月1日晚,李笑來會客內部語音遭泄露,在幣圈社群瘋傳。在網傳文字版中,李笑來懟遍了幣圈大佬,其言論包括:量子鏈是空氣幣、NEO是個傻*項目、孫晨宇是個騙子、趙長鵬人品不好,不懂技術還跟徐明星也有黑歷史等等。后李笑來團隊也公開其錄音中李笑來對于幣圈現狀和投資的看法,其觀點包括:1.不要盲?的相信“價值投資”;2. 散戶最?*;3. 不看好ETH,但是ETH成功了。看好EOS,EOS會更成功的;4. 流量+技術是關鍵,不做中間環節;5. 對那種概念的多中?化交易所不感冒;6.把底層?戶連接起來,才是最?逼的社群;7. 不管是投機還是投資,賺到錢的才是成功;8.不僅要做第?,?且要加快加速度。[2018/7/4]

無狀態客戶端

這個問題的一類解決方案基于“無狀態客戶端”的觀念。基本原理是,讓區塊驗證不再以持有全局狀態為前提。相反,區塊會自帶證據”),證明其所訪問狀態的值。就跟現在的設計一樣,區塊內會包含一個“狀態根”,所訪問的值可以對應著狀態根得到證明。以太坊現在的狀態樹方案支持這樣的證明技術,像二進制樹或者VerkleTrie這樣更高效的方案也可以。見證數據也會證明處理完該塊后新狀態根的正確性。

無狀態性有兩種形式:

弱無狀態性:出塊者仍然需要完整的狀態,以為區塊生成見證數據;但驗證區塊的階段可以是無狀態的;

強無狀態性:沒有任何節點需要完整的轉臺。反過來,是交易發送者需要提供見證數據,而出塊者可以聚合這些數據。交易發送者自己負責存儲為所關切的賬戶生成見證數據所需的部分狀態樹。

強無狀態性是一個非常“優雅”的解決方案,因為它把責任完全轉移給了用戶,雖然為了保證實踐中的良好用戶體驗,我們需要創造某些類型的協議來幫助不運行個人節點的用戶維護狀態、并處理用戶需要與意料之外的賬戶交互的情形。打造這樣的協議非常難。

此外,所有類型的無狀態性都提高了網絡所需的數據帶寬;而強無狀態性還需要交易聲明其所交互的賬戶及存儲項的鍵。

一個更溫和的解決方案:狀態過期

更溫和的解決方案可以歸結為不同形式的“狀態過期”方案。必須持續得到訪問的狀態才能保持“激活狀態”;而長期無人問津的狀態會變成“失活”。具體用什么機制來更新狀態,有很多選擇,但一般原則是,除非某個狀態對象被顯式地更新,否則就以某種形式處于失活狀態。因此,任何創建新狀態對象的活動,都只能成為節點在一段時間內的負擔,而不像現在這樣變成永久負擔。

失活狀態,故名思義,就不是“狀態”的一部分;想要處理區塊或創建區塊的節點無需存儲失活狀態。不過,失活狀態不是被完全刪除了!在所有類型的狀態過期提案中,都預設了某種方法可以“復活”已經失活的狀態。

一般原則是,激活狀態的使用與當前相同,而失活狀態則需通過上述無狀態客戶端的機制來使用。復活一個過期狀態對象的事務需要提供一個證據,來證明該對象是失活狀態的一部分。為了能夠生成這樣的證據,用戶自己需要存儲和維護至少一部分失活狀態。

何時過期

決定過期條件的設計也有很多種。最常見的幾種是:

直接租金:逐塊逐塊收取“租金”,直接以每個賬戶的余額來支付;狀態對象的余額降到了零,該賬戶就過期了。

剩余存活時間值:每個狀態對象都存儲一個”剩余存活時間“值,這個值可以通過支付費用來增加

觸達即刷新:每個狀態對象都存儲一個”剩余存活時間“值,并且每逢讀取或寫入該賬戶都會增加該值

所有狀態對象定期過期:也就是ReGenesis提案

我自己越來越喜歡”觸達即刷新“方案,因為它避免了應用需要創造復雜的經濟模型來讓用戶承擔狀態租金;以及它保證了激活狀態的規模有一個清晰的上限。讓大量狀態按照規律的時間間隔過期的方案也有同樣的好處,但也有一些有趣的權衡:關鍵好處是,過期方案更簡單,但關鍵不足是,跨過一個過期時點后,你再激活自己的狀態對象時,需要多少見證數據會跟你觸達狀態對象的時間點有關。

賬戶層面的過期vs.存儲槽層面的過期

狀態過期的邏輯既可以運營到賬戶層面,也可以運用到單個存儲槽層面。當前,我強烈偏向于在存儲槽層面實現狀態過期方案。因為很多合約賬戶的存儲槽數量是不受限制的,任意用戶都能加入合約并增加合約名下的存儲槽的數量。不管使用什么樣的賬戶層過期方案,想要實際限制狀態的規模,租金的數量都必須與合約內存儲槽的數量成比例。結果是,用戶還是能夠僅支付一次性的費用就給合約及其用戶施加永久的持續性成本。

要解決這個問題,合約要么加入復雜的內部邏輯,將存儲操的租金“轉嫁”給用戶,要么重新設計自己合約的模式,轉向使用CREATE2操作碼創建新的合約并使用這些合約來充當存儲槽。不管是哪種辦法,最后都會變成等價于存儲槽層面的過期方案。因此,我個人認為,我們應該僅在合約存儲槽層面實現狀態過期方案。

但是,存儲槽層面的過期方案也有自己的缺點:每個存儲槽都要增加一個元數據,指明它何時過期,這也意味著“復活沖突問題”不僅會影響賬戶,也會影響存儲槽。

Tags:以太坊比特幣加密貨幣KEI以太坊最新價格行情萊特幣和比特幣的區別圖片加密貨幣騙局話術MONONOKEINU

幣安交易所app下載
區塊鏈:貝萊德首席投資官:貝萊德已經開始“涉足”加密領域_CEDEX

貝萊德金融管理公司首席投資官RickRieder暗示,該公司已經將其投資組合的一部分投資于加密貨幣.

1900/1/1 0:00:00
KEX:BKEX Global 已完成平臺幣BKK第十七次二級市場周回購_okex幣幣杠桿交易教程

親愛的BKEXer: BKEXGlobal自2020年10月19日開啟BKK周回購銷毀制度,并于2021年2月9日16:00完成第十七次二級市場周回購.

1900/1/1 0:00:00
比特幣:新債王:對抗“印鈔機” 比特幣或許比黃金更好_FTX

比特幣勢如破竹之際,又一位大佬改變看法,加入了“吹幣”陣營,認為比特幣或是比黃金更好的交易對象.

1900/1/1 0:00:00
BTC:分析:吳忌寒為何出售BTC.com礦池?買家500.com是誰?_比特幣

2月16日500.com彩票網宣布,與比特小鹿的子公司BlockchainAlliance達成股份置換協議,收購BTC.com礦池業務.

1900/1/1 0:00:00
CRYP:德意志銀行計劃推出數字資產托管和交易平臺_Soccer Crypto

摘要: 德意志銀行有一個加密貨幣托管平臺的原型。根據計劃,其平臺將從為機構投資者提供托管服務開始,一直拓展到代幣發行和交易服務。這些計劃發表在世界經濟論壇2020年12月發布的一份報告中.

1900/1/1 0:00:00
SDT:幣安礦池第30期雙幣寶理財產品上線_imtoken里的usdt提現人民幣教程

親愛的用戶: 幣安礦池上線第30期“雙幣寶”理財產品,邀您體驗!申購方式:先到先得申購時間:2021年02月17日中午12:00至2021年02月18日中午12:00理財產品列表 數字資產 周期.

1900/1/1 0:00:00
ads