所有語言
分享
作者:2077 Research 來源:X,@2077Research 翻譯:善歐巴,金色財經
隨着以太坊網絡不斷髮展成熟,理解不同類型節點的概念變得愈發重要。然而,現實是大多數用戶並不願意運行節點,即使硬件需求對許多活躍用戶而言已經不再是問題。
在以太坊發展的“終局”中,用戶必須能夠在無需複雜技術知識或資源的情況下驗證狀態完整性和數據可用性。畢竟,如果區塊鏈無法實現驗證,它就只是一種效率低下的數據庫。
本文將探討三種關鍵類型的節點,這些節點將塑造以太坊網絡的未來:無狀態節點、狀態節點以及完整/存檔節點。我們將研究無狀態節點如何利用零知識證明實現新區塊的可信驗證,狀態節點如何提供快速且可信的以太坊當前狀態訪問,以及完整/存檔節點如何存儲從創世區塊開始的完整鏈歷史。通過理解每種節點類型的角色與權衡,我們可以邁向更去中心化、更安全、更具擴展性的以太坊生態系統。
目前,大多數用戶不願意花費精力運行任何類型的節點,儘管對於比特幣和以太坊來說,運行節點的硬件需求對許多鏈上活躍用戶而言完全可以負擔。“活躍用戶”指的是那些鏈上資產規模較大的用戶,他們並不是因為硬件成本而不運行節點。
主要原因可能是以下幾點的綜合作用:絕大多數用戶並不關心運行節點,也不願花幾百美元購買硬件,或者缺乏運行節點的技術知識。儘管比特幣和以太坊在降低運行難度方面取得了很大進展,但對於普通非技術用戶來說,這仍然是一個複雜的任務。
無狀態以太坊的願景
我認為,在每條區塊鏈的“終局”中,用戶需要能夠驗證狀態完整性和數據可用性,而不需要理解這些概念是什麼。好消息是,這一願景通過足夠的工程能力是完全可行的(藉助零知識技術和一些數據可用性採樣)。
在這種終局中,幾乎所有值得使用的錢包都將內置一個無狀態節點。當區塊鏈添加新塊時,該節點可以通過 P2P 網絡向任何完整節點請求最新區塊頭及零知識證明,驗證狀態從前一區塊頭到新區塊頭的變更是正確的,同時通過向幾個節點請求隨機數據樣本,以接近 100% 的信心確認所有數據(包括數據塊和執行數據)已發布。此外,它還可以獲取一個零知識證明,證明網絡已就該區塊達成共識並完成最終確認。
所需的帶寬和計算資源非常小,完全可以在手機甚至智能手錶上完成(@drakefjustin 常提到這一點)。這種節點被歸類為“無狀態”節點,因為它可以在不本地保存當前狀態的情況下,依賴不同類型的證明來驗證新區塊。
這些證明不必是 zk 證明。在我們能夠使用 zk 證明執行上述內容之前,我們將進行無狀態執行驗證。事實上,無狀態執行今天可以實現,但對於當前的 Merkle-Patricia-Tree 結構來說效率非常低,見證證明太大而無法實用。
這是無狀態執行在當前 Merkle-Patricia 樹中遇到的主要問題,此屏幕截圖中的許多區塊都遠小於 100kb,而無狀態驗證所需的證明通常比區塊本身大 50 倍以上。
然而,以太坊將來會將其狀態樹結構升級為不同於當前的 Merkle-Patricia-Tree 結構。你們中的許多人可能聽說過多年來一直在路線圖上的 Verkle 樹,它們將允許創建實用的無狀態客戶端,因為 Verkle 樹結構的性質允許非常小的見證/證明。
Verkle 樹的一個主要問題是它們並不具有量子安全性。這意味着它們充其量只是狀態樹結構的臨時解決方案,直到有成熟且高效的永久性解決方案出現。最終的解決方案可能會是基於 STARK 證明的二進制哈希樹(STARK-proven binary hash tree)。事實上,很可能 Verkle 樹會被跳過,直接採用某種形式的 STARK 證明的二進制哈希樹(相關梗圖見 @VitalikButerin)。
無狀態節點一個非常有趣的選項是,它可以選擇不完全無狀態。例如,節點可以根據用戶的需求,本地存儲與其用例相關的狀態數據(前提是客戶端支持該功能)。
假設你的資產分散在多個地址、資產種類和 DeFi 協議中,那麼你可以將與自己用例相關的所有狀態數據本地寫入磁盤,而僅需消耗極少的磁盤空間。即使跟蹤多個大型 DeFi 協議的完整狀態數據也僅需幾 GB,而考慮到幾乎所有新款手機都配備了 128GB 或更多存儲空間,用戶在手機閃存中存儲自己所需的狀態數據不僅可行,而且可能相當實用。
(關於輕客戶端的簡短說明:在一個無狀態客戶端能夠輕鬆高效地驗證狀態轉換和共識的世界中,我認為傳統依賴誠實多數假設的輕客戶端將不再有實際用途。)
狀態節點僅保存當前狀態和最近的狀態數據,刪除所有超過一定時間的數據(詳見 EIP-4444 提案)。當前狀態對於本地構建區塊是必要的,而這是無狀態節點無法完成的功能。
有狀態節點不應與“完整”節點混淆,因為有狀態節點不會保存完整的鏈歷史,因為這在未來會變得非常數據密集。有狀態節點對於任何想要快速且無需信任地訪問以太坊當前狀態的用戶都很有用,無論是從狀態查詢數據、構建區塊還是使用這種類型的節點進行質押。
保留在消費級硬件上運行有狀態節點的可能性是一個非常重要的目標,我認為,即使無狀態節點非常輕量和成熟,以太坊社區也必須保留這一目標。其中一個主要原因是,所有無狀態節點都依賴有狀態節點來創建新區塊無狀態驗證所需的見證。
還需要訪問當前狀態才能知道內存池中的交易是否有效,因此,在網絡上擁有一組非常分散的狀態節點非常重要,這些節點可以通過某種形式的包含列表設計確保非常強大的審查抵抗保證。
好消息是,有了狀態到期機制,我們可以大大簡化有狀態節點的運行,因為一段時間內無人交互的狀態可以從節點的磁盤中刪除,任何想要與已到期狀態交互的人都必須提供見證(本質上是默克爾證明)才能將已到期狀態恢復到當前狀態。任何有權訪問鏈歷史的人都可以以無需信任的方式構建這些類型的證明來恢復已到期狀態。截至撰寫本文時,以太坊狀態已接近 300gb,在實施某種形式的狀態到期機制之前,狀態大小將繼續以或多或少的上升趨勢增長。
出於本文的目的,我將批量處理完整節點和存檔節點,因為普通完整節點可以使用其寫入磁盤的信息在本地計算存檔節點寫入磁盤的所有數據。不同之處在於,完整節點會修剪不再是最新/近期狀態的狀態。例如,您無法從普通完整節點查詢“大約 5 年前區塊 Y 上賬戶 X 的 ETH 餘額是多少”,而存檔節點會在一毫秒內回答該查詢。
也就是說,理論上可以從完整節點寫入磁盤的數據(整個鏈歷史)計算出此查詢的答案,但支持此功能的執行客戶端並不多。我認為,認為許多用戶(甚至是高級用戶)將在 10 年內運行完整/存檔節點是不合理的,要使這成為一個合理的選擇,我們必須將 L1 吞吐量限制在完全不合理的水平,因為我們可以在 L1 上以最小的權衡獲得更高的吞吐量。當大多數用戶可以使用 zk 證明輕鬆驗證新塊時,我認為當收益如此巨大時,這是一個值得追求的權衡。
也許我們可以獲得能夠在 HDD 上高效運行的執行客戶端,並且能夠以相對低廉的價格存儲數百 TB 的存檔狀態。這樣可以讓出於任何原因想要存檔所有以太坊的用戶這樣做,我知道 Erigons 的目標之一是允許在 HDD 上運行完整存檔節點。
未來,以太坊的形態將由其網絡節點的構成決定。通過讓無狀態節點成為大多數用戶的現實選擇,同時認識到狀態節點和完整/存檔節點的重要性,以太坊可以在去中心化、安全性和擴展性之間找到完美的平衡,為所有用戶帶來福祉。