科普|如何開發出好用的輕客戶端,Part-1
科普|如何開發出好用的輕客戶端,Part-2
大多數錢包軟件都依賴于Infura等中心化提供商。如果我們想要別出心裁一些,就需要開發一個可以在低資源設備上運行的新型輕客戶端。
在本文中,我們將介紹以太坊狀態是什么,以及如何讓輕客戶端輕而易舉地獲得它。
以太坊狀態
當我們提到“狀態”時,我們指的是所有賬戶信息以及所有存儲在智能合約中的數據。目前,狀態包括:
1.32億個賬戶大約10GB的賬戶數據大約30GB的合約storage數據大約60GB的Trie節點經常性數據我們先來看一下客戶端目前是如何訪問狀態的。
同步
以太坊節點需要訪問完整的狀態才能處理新挖出的區塊。我們可以通過執行從創世塊開始到鏈首塊的每個區塊來從頭計算出狀態。通常情況下,我們不會采用這個方法,因為計算成本太高。
客戶端傾向于直接從其它完全同步的客戶端那里獲取完整的狀態副本。雖然不同的客戶端執行該操作的具體方式不同,但無論是哪種客戶端,在首次上線或離線一段時間后再次上線的情況下,通常都要花費一段時間同步至最新區塊。
TRON數字錢包科普資料《波場錢包的現在過去與未來》已上線:據最新消息顯示,由TokenPocket聯合波場TRON官方,以及 TokenPocket 社區志愿者共同撰寫的《波場錢包的現在過去與未來》已正式上線。《波場錢包的現在過去與未來》又稱為波場錢包小白書,詳細介紹了當前TRON錢包與TRON生態密切結合的實例,是目前市面上最為詳細的TRON數字錢包科普資料。波場錢包作為波場公鏈生態中極為重要的入口,是波場生態的重要構成要素。波場錢包從一開始只提供權限管理、轉賬收款、節點投票等基礎功能,到如今不僅可以為用戶提供法幣交易、閃兌和去中心化交易所等方便快捷的交易服務,還能讓用戶直接在錢包上體驗波場上DApp,挖礦、DeFi、Staking等資產增值服務。詳情見原文鏈接。[2020/8/20]
同步可能需要花費很多時間。如果你使用自己的節點與區塊鏈交互,這會是一大缺陷。要讓客戶端一直保持同步狀態,你不僅需要花時間等待客戶端同步,還需要消耗計算機的計算和存儲資源。
我們的解決方案是專門針對資源受限的設備而設計的,可以一舉解決上述兩個問題。我們的輕客戶端在運行時只需消耗最少的CPU/RAM/HDD/帶寬資源,而且可以保證永遠在線。
現場 | 火幣中國推出數字經濟及區塊鏈產業科普新書:金色財經現場報道,12月6日,由海南省工業和信息化廳主辦,南南合作金融中心協辦,海南生態軟件園、火幣中國承辦的“海南自貿港數字經濟和區塊鏈國際合作論壇”在海口舉行,這是全球首次區塊鏈部長級論壇。
在本次論壇上,火幣中國舉行了“數字經濟及區塊鏈產業科普系列新書發布”儀式,希望通過教材、專業教育、培訓等多種方式,幫助從業者、高校、研究機構深入了解區塊鏈,從而建立起區塊鏈全局性知識模型,真正推動區塊鏈應用落地。火幣中國CEO袁煜明介紹,將聯合機械工業出版社面向普通高等教育推出《區塊鏈導論》、《區塊鏈系統設計與應用》和《區塊鏈新商業模式分析》系列教材,這是國內最早推動的區塊鏈教材之一;火幣中國還積極參與數字經濟的研究,由中信出版社出版的新書《讀懂Libra》已經上市;由火幣中國負責編寫的區塊鏈技術科普讀物《區塊鏈技術進階指南》將于12月面世;首本行業內最全的區塊鏈應用案例集《區塊鏈產業應用100例》在本次論壇進行了首次刊印。[2019/12/6]
當然了,不同的設備之間存在差異,甚至有可能出現無法承受基礎負載的情況。為了應對這一情況,我們正在努力免去完全同步的需求。在我們設計的模型下,客戶端只需要準確獲得鏈首塊的信息即可。
動態 | 浙江衛視節目科普支付寶區塊鏈防偽溯源產品:昨日,在浙江衛視播出的科普綜藝欄目《智造將來》現場,支付寶首次展示了支付寶區塊鏈防偽溯源產品,以接地氣的方式公開向大眾展示區塊鏈在生活中的應用。[2019/3/4]
我們的最終目標是構建一個在首次安裝或離線一段時間后再次上線能夠立即使用的客戶端。這個客戶端只需能訪問正確的數據即可。
按需狀態可得性
在如今的DevP2P以太坊協議中,有一個名為GetNodeData的消息。它可以用來檢索以太坊狀態的任意部分。我們已經在Trinity中使用該網絡消息來開發“Beam”同步模式并證明了其可行性。這是我們進行的基礎研究之一,旨在證明這種新型輕客戶端是可以實現的。
遺憾的是,當前的DevP2P以太坊網絡并不合適用于輕客戶端用例,因為它需要每個節點都能存儲超過40GB的狀態數據,并提供狀態的任意部分。無法響應這些狀態數據請求的節點不太可能維持健康的對等連接。
按需狀態訪問模式
當前網絡的設計是同步完整狀態。GetNodeData消息適合我們的按需狀態檢索實驗只是一個巧合。為了讓客戶端能夠同步完整的狀態,高效的訪問模式是按順序遍歷數據,獲得連續的大數據塊。然而,在錢包用例以及我們的新型輕節點用例中,訪問狀態的需要需要很大程度上是隨機的。
金色財經獨家分析 監管機構、媒體、業界提示詐騙風險 區塊鏈科普道阻且長:新華社今日發文表示,近來“區塊鏈”類詐騙案件頻發,不法分子以“投資虛擬貨幣周期短、收益高、風險低”為借口,騙取用戶信任并誘使其轉賬進行投資。無獨有偶,同日消息,騰訊手機管家安全專家也提醒此類風險,并從技術上提出防騙建議。在美國,監管機構警示加密貨幣欺詐現象普遍承諾高收益而不披露潛在風險。金色財經獨家分析,不法分子假借新技術之名進行詐騙,一方面是抓住民眾趨利的心理,一方面反映出區塊鏈科普的欠缺。區塊鏈是新興科技和底層技術并有改變社會生產關系的潛力,應該進行系統性的科普教育,當前,部分大學已經開始設置了區塊鏈課程,但對于普通民眾仍然有科普的需求,人們應該了解到系統和正確的知識,不僅要了解區塊鏈的好,也要明確局限和弊端,以在高收益的誘惑下,保持清醒客觀。[2018/4/11]
錢包訪問狀態的主要方式是通過以下JSON-RPC方法:
eth_getBalance用來檢查賬戶余額eth_call用來查詢合約數據eth_getTransactionCount和eth_estimateGas用來構建交易eth_getBalance和eth_getTransactionCount僅從主要賬戶Trie中讀取值。因此,可以通過調用該方法獲得Trie上現有的1億多個賬戶中任意一個地址的情況。
財政部副部長朱光耀:數字經濟還處在發展的過程中,要以科普、推動的態度來推進數字經濟發展:今日,在中國發展高層論壇2018年會上,財政部副部長朱光耀表示:“數字經濟還處在發展的過程中,要以科普、推動的態度來推進數字經濟發展。也要關注數字經濟的其他影響,包括稅收征管、反洗錢監管措施等要跟上。”[2018/3/25]
eth_call和eth_estimateGas都涉及實際的EVM執行。EVM執行可以從1億多個賬戶中的任意一個及其底層合約存儲Trie中讀取數據。
我們發現,錢包只需讀取少量數據,而且讀取的需要是隨機的。這在根本上與同步完整狀態不同,因此這兩個用例不太可能通過同一個解決方案來解決。
我們需要解決的問題
新的網絡需要解決當前網絡存在的一些缺陷。
如何分擔并降低存儲壓力
這個網絡上的節點要能為存儲完整狀態貢獻少量存儲空間。我們想讓網絡中的每個節點存儲一小部分狀態,而非完全復制所有狀態。有了足夠多的節點,整個網絡就可以輕而易舉地以極高的復制因子存儲所有狀態。
如何找到你需要的狀態
由于每個節點只需存儲小部分狀態,我們再也不能盲目地向網絡中的任意節點請求數據。因此,網絡需要一個節點發現機制,以便節點獲取所需數據。
如何確保數據永遠是最新的
不同于可以構建成只能添加型文件的區塊鏈歷史記錄,以太坊狀態是持續變化的。每個交易都會導致賬戶余額和合約存儲發生變化,這些更新需要在網絡中廣播。
如何從網絡中讀取數據
重要的是,客戶端要能高效地從網絡中讀取數據。調用eth_estimateGas將根據最新的狀態根預測執行交易,來確定交易需要消耗的gas。如果是一個只涉及兩個賬號的簡單轉賬交易,所需的數據量相對較小。然而,如果是與智能合約交互并且需要用到合約存儲的復雜交易,客戶端需要從數據庫讀取的數據量則大得多。
假設一次網絡往返需要100ms,那么一筆需要100個狀態部分的交易需要花費大約10秒時間來估算gas使用量。如果延遲太久,一些操作可能需要花費過多時間才能完成,這會大幅降低網絡的可用性。
如何解決合約存儲失衡問題
賬戶Trie在設計上是平衡的,但合約存儲不是。這就導致合約存儲很難處理。
潛在解決方案
人們正在積極研究按需狀態可得性。目前,我們還不清楚該研究的未來方向,但是我們目前主要聚焦于兩個不同的方法。
GetNodeData風格的原生KademliaDHT
我們可以采用的最簡單的解決方案之一就是,采用與GetNodeData相同的運作方式,但是僅要求每個節點存儲距離自己最近的數據,而非所有數據。Trie上的每個節點都有一個哈希值,我們可以使用這些哈希值將Trie數據與DHT鍵空間關聯起來。你可能還記得,KademliaDHT網絡有一個新特性:遍歷鍵空間只需O(log(N))。
這個方法的缺陷在于效率和速度。存儲由單個節點哈希哈希作為鍵的Trie數據需要存儲大量中介Trie節點,這會導致網絡需要存儲的數據總量翻倍。
這個方法也會讓數據檢索變得低效。通過該結構查找數據時,你必須從狀態根開始遍歷Trie節點。對于賬戶Trie來說,這平均需要7次查詢,才能獲得實際的賬戶數據。
這個方法確實具有很大的優勢。它徹底避開了合約存儲失衡問題,因為各個Trie節點的哈希值是隨機的,因此數據會自動呈隨機分布。再進一步來看,如果網絡大到足以存儲完整的6TB存檔歷史,這個網絡最終將變成一個歸檔節點。
這個方法的另一個主要優勢是,可以免去對證明的需求。我們直接構建Trie和所有中間節點,因此無需相關的默克爾證明。
目前,我們正在努力確定這個方法是否能夠達到性能要求。
葉子節點和證明
另一個方法是將Trie的葉子節點組成共享同一條基礎路徑的連續的塊。各個節點會存儲KademliaDHT網絡中離自己最近的Trie路徑“周圍”的所有葉子節點。對于高度平衡的賬戶Trie來說,這個方法非常有吸引力。
通過Trie路徑處理數據,我們無需遍歷Trie,訪問葉子數據的復雜度將下降到O(1)。如果你還記得的話,GetNodeData風格的原生方法平均需要7次網絡往返,才能訪問存儲在Trie葉子節點中的數據。然而,本節所介紹的方法在性能上的優勢非常重要,而且是實現網絡可用性必不可少的。
這個方法的優勢也是有代價的。確保數據是最新的會極大提高復雜性。有很多方法可以做到這點,但是每個方法都有權衡取舍。雖然數據可以就地更新,但是這需要每個節點都進行昂貴的計算。或者,每次挖出一個新的區塊后,更新后的證明都會廣播至全網節點。這些方法都在計算和帶寬之間進行了權衡取舍。但無論是計算還是帶寬,這兩個在我們眼中都是稀缺資源。
我們的研究結果將指明我們的新網絡要采取的發展方向。
本系列的下一篇文章應該是最后一篇介紹性的材料。我們將檢視這種新型的客戶端實際長什么樣,以及我們如何理解它的使用方式。我們將提供概要的路線圖,說明我們將如何實現它;以及,我們所做的一切與“無狀態以太坊”有何關聯。
原文鏈接:https://snakecharmers.ethereum.org/the-winding-road-to-functional-light-clients-part-3/作者:PiperMerriam翻譯&校對:閔敏&阿劍
以太坊聯合創始人VitalikButerin在研究機構Flashbots的GitHub倉庫中提議利用Flashbots作為“賬戶抽象”的一種實現方式.
1900/1/1 0:00:00撰文?|?SHIER 出品?|NEST愛好者 今天跟大家分享一下:什么DAPP都不需要依賴,通過Etherscan就可以與以太坊智能合約進行直接交互的教程.
1900/1/1 0:00:00YAMFinance在推特上表示,我們將與UMAprotocol合作,為我們的新產品uSTONKS打氣,明天在#DegenerativeFinance上發布.
1900/1/1 0:00:00MakersPlace宣布將啟動抽獎活動BEEPLERAFFLE,將此前因網站崩潰未售出的剩余BEEPLE1美元特價加密藝術NFT以抽獎活動發送給幸運用戶.
1900/1/1 0:00:00區塊鏈支付解決方案開發商GreenBoxPOS周五向SEC提交首次公開募股申請,希望在NASDAQCapitalMarket上市,交易代碼GBOX,募資額目標最多達4600萬美元.
1900/1/1 0:00:00經過一段時間的積累后,鯨魚們在2月開始持續“卸貨”BTC。據加密市場數據聚合商Glassnode的最新報告,比特幣鯨魚在2月期間“卸掉”了大量的BTC.
1900/1/1 0:00:00