科普| 如何開發出好用的輕量級客戶端,Part-1

大約5 年前,我們開始構建Trinity —— 以太坊網絡上的新型“輕量級客戶端”。那時候Geth 剛剛發布了第一版LES 協議,而我們曾心懷遠大的夢想。

遠大的夢想往往被現實所擊倒。這些年來,我們得到了一些教訓:

EVM 計算從根本上來說是“繁重的”。 LES 如同茫茫沙漠,客戶端就是沙漠中渴求數據的旅人。同步並維護狀態的難度過高。區塊鏈上的歷史記錄在絕大多數情況下是無用的,卻是必不可少的。核心以太坊協議在本質上對“輕量級” 不友好。 Python 太慢了。

我們的目標是遠大的,方法是有缺陷的。現在是該從頭再來的時候了。

訪問以太坊協議

如果你想要與以太坊協議交互,擺在你面前的是兩個選擇:

自己運行客戶端。使用Infura 等中心化提供商的服務。

上述兩個選擇可以滿足大多數用例的要求,但是它們位於兩個極端。以太坊客戶端需要消耗大量磁盤空間,花費數小時乃至數天時間進行同步,而且對CPU 和內存的佔用通常很大。中心化提供商是一種簡單可靠的方案,但是要以犧牲隱私性、安全性和去中心化原則為代價。

為什麼我們不能有介於二者之間的第三種選擇?互聯網已經證明過很多次了了,在困難模式和簡單模式之間,人們往往會選擇後者。

自己託管郵件(難) vs. Gmail(易)購買DVD 或CD(難)vs. 盜版(易)盜版(難)vs. 流媒體(易)自己運行以太坊節點(難)vs. Infura(易)

我想過採用隱私保護型解決方案。然而,我的所有交易都是通過MyCrypto 或Metamask 完成的。這兩款錢包都來自中心化提供商。它們都支持用戶使用自己的節點,但是就現有的客戶端來說,我認為這麼做成本太高。如果我們想與這些中心化解決方案爭奪市場份額,我們需要為用戶提供更好的選擇。

我們對客戶端的要求是:

能夠在資源有限的設備上運行(1 CPU / 1GB RAM / 磁盤佔用量<1GB)公開標準“錢包” 應用所需的API不需要同步

從用戶的角度來說,我希望讓客戶端時刻保持運行,而不會影響我的設備的性能。我希望在離線一段時間後,再上線時無需等待客戶端同步。

這就是我心中的“聖杯”,是我捨命也要攀登的高峰。

錢包

我們這裡講的是如何為錢包構建一個完美的客戶端。錢包無處不在,而且主要由中心化提供商支持。總的來說,錢包要滿足以下需求:

追踪區塊鏈的最新區塊查看賬戶餘額和nonce讀取合約信息(如代幣餘額)估算交易的gas limit發送交易監控需要打包的待處理交易

大多數錢包都採用標準化的JSON-RPC API。根據上述需求轉化成的JSON-RPC 端點如下所示:

eth_blockNumber用來追踪鏈首塊eth_getBalance和eth_getTransactionCount用來查看賬戶信息eth_call用來讀取合約信息eth_estimateGas用來估算gas limiteth_sendRawTransaction用來發送交易eth_getTransactionReceipt表示交易已經被挖出

如果我們更深入分析該功能的必備條件,就會得到更低一級的需求:

訪問賬戶和合約存儲以支持eth_call、eth_estimateGas、eth_getBalance和eth_getTransactionCount訪問gossip網絡來追踪鏈首塊和eth_sendRawTransaction訪問鏈上歷史記錄來獲得eth_getTransactionReceipt

因此,如果我們可以滿足這些需求,就可以構建一個適合輕量級錢包的客戶端,不需要同步,也無需犧牲隱私性和安全性。

如今的以太坊網絡

目前,以太坊客戶端可以在以太坊協議和LES DevP2P 協議之間進行選擇。

LES 協議採用服務器/客戶端模型。在該模型中,數據會根據要求從服務器流向客戶端。該協議不允許客戶端通過任何有意義的方式返回數據,這點可以從協議狀態看出。根據我的經驗來看,LES 協議中的服務器和客戶端在數量上嚴重失衡。運行服務器的成本很高,現有服務器的數量不足。這就導致LES 變得不可靠,而且經常會變得完全不可用。

以太坊協議則另有缺陷。該協議很好地達到了目的,確保網絡中所有的節點都盡可能地複制了完整的歷史記錄和狀態數據。這對客戶端的要求很高。網絡中的每個節點都必須保存完整的歷史記錄和狀態。沒有保存這些數據的節點不太可能保持健康的點對點連接,可能會在無法滿足對等節點的數據要求時斷開連接。

在本系列文章中,我們想要解構以太坊協議這一“龐然大物”。該協議包含了我們理想的客戶端類型的所必備的一切功能。它的設計適合全節點和礦工,但是不適合我們所概述的輕量級客戶端。

解構以太坊協議

讓我們將目光轉向以太坊協議……

我們需要解決這個問題。在與以太坊協議交互時,人們可選擇的方式有限,而且高度依賴中心化提供商。當前的網絡狀態就預示了未來可能發生的情況。

我們構想了另一種適用於以太坊錢包的輕量級客戶端。這一構想不只是一個想法,而是以實驗、原型以及我們對現有協議不斷深入的認知為基礎的。

我們正在研究的解決方案需要對核心以太坊協議進行一些修改,以便支持該用例。在該系列的下一篇文章中,我將概述需要修改和新增的部分,以及我們計劃如何去實現它們。最重要的是,我將講述我自己對這一新型輕量級客戶端的用戶體驗的期望。

(未完)

(文內有許多超鏈接,可點擊左下”閱讀原文“ 從EthFans 網站上獲取)

原文鏈接:

https://snakecharmers.ethereum.org/the-winding-road-to-functional-light-clients/

作者: Piper Merriam

翻譯&校對:

閔敏& 阿劍


分享至:

作者:PA荐读

本文為PANews入駐專欄作者的觀點,不代表PANews立場,不承擔法律責任。

文章及觀點也不構成投資意見

圖片來源:PA荐读如有侵權,請聯絡作者刪除。

關注PANews官方賬號,一起穿越牛熊
推薦閱讀
4小時前
5小時前
6小時前
11小時前
11小時前
14小時前

熱門文章

行業要聞
市場熱點
精選讀物

精選專題

App内阅读