比特幣行情 比特幣行情
Ctrl+D 比特幣行情
ads
首頁 > 聚幣 > Info

比特幣:觀點 | 以太坊狀態規模管理諸提議(上)

Author:

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

寫于2021年2月12日

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

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

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

引言:問題出在哪?

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

Ripple政策主管反駁SEC主席觀點:加密貨幣與證券不同,一刀切的方法不可行:4月8日消息,在最近的一篇推文中,美國證券交易委員會(SEC)主席Gary Gensler表示,加密市場與證券法沒有任何不兼容之處。他強調,SEC的目標是使加密領域符合這一立法,確保數字資產的投資者獲得與其他市場相同的保護。

然而,Ripple的政策主管Susan Friedman表示,Gensler的聲明中存在一個關鍵缺陷。他指出,與證券不同,加密貨幣通常不涉及對要約人的財務索賠,并且可以在沒有中介的情況下實時結算。她認為,這種差異需要具體的規則,而不是千篇一律的保證,即一刀切的方法是正確的運作方式。(U.Today)[2023/4/8 13:51:08]

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

賬戶的ETH余額和nonce

智能合約的代碼

智能合約的存儲項

與共識機制相關的數據

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

觀點:使用第三方托管機構的人大量采用并不是比特幣的大規模采用:加密貨幣托管公司Casa聯合創始人兼CTO Jameson Lopp轉發的觀點表示,使用第三方托管機構的人大量采用并不是比特幣的大規模裁采用,而是大量采用比特幣IOU。原觀點指出,在一個充斥著數字黑客和監管不確定性的世界里,冷錢包是最安全的選擇。但大多數持有黃金投資組合的投資者都是通過經紀機構購買ETF的股票,他們實際上根本不持有任何黃金。事實上,他們所擁有的只是一張紙證,表明他們有權獲得相關黃金的市場價值。他們無法從ETF中提取實物黃金。對于大多數普通投資者來說,這對他們來說完全可以。

BTC和加密社區的人員通常是超前或者具有一定技術水平,對他們來說,冷錢包是完全有意義的。進入頂級安全級別的技術壁壘并不太高,而且是一個無需考慮的問題。但是對于普通的大街投資者,Robinhood和PayPal是完美的解決方案,是可以理解和訪問的切入點。并不是每個黃金投資者都希望或需要在地下室購買實物金條,比特幣和加密貨幣也是如此。

注:IOU相當于一份靠交易所名譽擔保的欠條。[2020/11/23 21:47:01]

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

觀點:歷史表明,美國總統選舉往往標志著比特幣牛市轉折點:CryptoSlate發文分析稱,長期以來,美國總統大選一直被視為經濟趨勢的重要催化劑,潛在的權力更迭往往會改變全球市場的走向。許多分析人士預計,比特幣的價格也會受到選舉的影響。歷史的確表明,選舉是比特幣的轉折點,而且通常對其有利。比特幣是在2008年大選后幾個月推出的,2012年的拋物線周期是在奧巴馬總統的第二任期選舉后開始的,2016年的牛市趨勢是在特朗普總統2016年大選后不久開始的。

在過去幾個月里,比特幣的價格從數月低點9900美元上漲到不到一周前創下的14100美元的高點。如果歷史重演,2020年的大選可能標志著比特幣的下一個拋物線趨勢的開始,目前這種趨勢已經開始出現一些跡象。[2020/11/4 11:38:07]

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

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

觀點:比特幣網絡難度將繼續上漲但要低于2016年:7月7日,加密貨幣分析師PlanB發推文稱,通過對比2012、2016和2020年比特幣減半前后網絡難度,從而預測2020年已經減半后的比特幣網絡難度將會繼續上漲,但總體要低于2016年的難度。[2020/7/7]

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

無狀態客戶端

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

聲音 | 觀點:2020年BitMex在加密衍生品市場的主導地位將大幅下降:Three Arrows Capital首席執行官Su Zhu發推稱,預測在2020年,BitMex在整個加密衍生品市場的主導地位將大幅下降,原因如下:1. 零產品創新;2. 對交易山寨幣/比特幣衍生品失去興趣3. 眾多反應迅捷的競爭者在各個維度上快速成長并吸引新客戶;4. 監管問題。[2019/12/24]

無狀態性有兩種形式:

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

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

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

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

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

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

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

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

**

**

何時過期

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

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

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

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

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

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

**

**

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

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

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

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

原文鏈接:

https://hackmd.io/@HWeNw8hNRimMm2m2GH56Cw/state_size_management

作者:VitalikButerin

翻譯:阿劍

你可能還喜歡:

干貨|以太坊無狀態客戶端初探

引介|ReGenesis:重啟以太坊以降低節點的負擔

觀點|以“狀態”視角理解以太坊及其未來

免責聲明:作為區塊鏈信息平臺,本站所發布文章僅代表作者個人觀點,與鏈聞ChainNews立場無關。文章內的信息、意見等均僅供參考,并非作為或被視為實際投資建議。

本文來源于非小號媒體平臺:

VitalikButerin

現已在非小號資訊平臺發布38篇作品,

非小號開放平臺歡迎幣圈作者入駐

入駐指南:

/apply_guide/

本文網址:

/news/9688831.html

免責聲明:

1.資訊內容不構成投資建議,投資者應獨立決策并自行承擔風險

2.本文版權歸屬原作所有,僅代表作者本人觀點,不代表非小號的觀點或立場

上一篇:

盤點零知識證明代表性項目:如何影響和塑造區塊鏈生態系統?

Tags:比特幣以太坊加密貨幣區塊鏈比特幣總市值最高點多少萬億以太坊交易所委托掛單要收手續費嗎加密貨幣是干什么用的區塊鏈騙了多少人

聚幣
LBA:關于LBank調整「幣生息」RAZOR年化收益率的公告

尊敬的LBank用戶: 出于對資產管理安全穩健的保障,LBank已于2月18日對「幣生息」RAZOR的年化收益率作如下調整:動態 | 迪拜商會與迪拜最大銀行簽署關于區塊鏈貿易解決方案的諒解備忘錄.

1900/1/1 0:00:00
COM:解密神秘500.com:今年預計挖2500枚比特幣,背后清華紫光或造礦機?

吳說作者|ColinWu本期編輯|?ColinWu目前美股加密礦業公司主要分成三類:第一類是傳統的中國礦機廠商嘉楠和億邦,此后可能還有神馬與比特大陸.

1900/1/1 0:00:00
USDT:關于LBank開啟「LBK周四GO」36期-八折DODO專場售賣的公告

尊敬的LBank用戶: 為回饋LBK社區用戶,LBank將開啟「LBK周四GO」DODO八折專場售賣。本次售賣將于2月18日啟動,本輪售賣共打折出售等值50,000USDT的DODO.

1900/1/1 0:00:00
以太坊:特斯拉會購買 ETH 嗎?

原標題:特斯拉真的需要以太坊2020年1月29日,電動汽車巨頭特斯拉創始人ElonMusk將自己的Twitter個人簽名改為“#bitcoin”,之后比特幣價格飆升了20%;2020年2月9日.

1900/1/1 0:00:00
區塊鏈:星球前線|德意志銀行計劃推出數字資產托管和交易平臺

本文來自Decrypt,作者:JeffBensonOdaily星球日報譯者|余順遂德意志銀行有一個加密貨幣托管平臺的原型.

1900/1/1 0:00:00
比特幣:特斯拉投資比特幣的背后:重估比特幣價值

這兩天的比特幣,正穩穩地站在5萬美元的關口之上。這意味著在剛剛到來的2021年,漲幅就已經超過了83%。關于比特幣在2021年表現的預測,都需要站在新的起點上去重估.

1900/1/1 0:00:00
ads