最近舉行的第90期核心開發者會議幾乎全程都在討論一個問題。我強烈建議大家親自聽一下這場會議。
在這場會議上,Alexey提出了客戶端開發者負荷過重的問題。雖然我認為這場討論是一個重要的開始,但是我們太急于尋求解決方案了,充分理解這個問題才是當務之急。重要的是,我們需要花點時間來分析問題。在問題內涵的分析上,“五問法”是最簡單有效的方法之一。
事不宜遲,先來看看第一問是什么。
第一問:為什么Geth開發團隊的壓力如此之大,甚至到了超負荷的地步?
通過etherscan,我們可以看到各個客戶端的裝機量所占份額的統計數據如下所示:
Geth:75%
Parity&OpenEthereum:20%
Nethermind:1%
剩下4%由一些市場份額不到1%的客戶端組成,因此忽略不計。
重要的是,有超過51%的算力都集中在Geth客戶端上。假設在即將到來的柏林硬分叉中,Geth在實現其中一個EIP時出現了bug。即使這個客戶端的其它實現都沒出bug,只要有區塊碰上了這個bug,就會導致以太坊網絡分叉。按理來說,這個區塊是無效的,其他客戶端也會將其視為無效塊。但是,有超過51%的挖礦節點都運行的Geth客戶端,因此整個網絡都會被帶到錯誤的分叉鏈上去。
外媒:拜登同意美財長耶倫的反加密貨幣觀點:美國新聞秘書Jen Psaki在周四的新聞發布會上表示,對于監管加密貨幣,拜登總統遵從了財政部長珍妮特·耶倫(Janet Yellen)的觀點。據悉,在今年1月的確認聽證會上,耶倫對立法者呼吁,應“減少”加密貨幣的使用。她表示:“我認為我們確實需要研究減少使用加密貨幣的方式,并確保不會通過這些渠道進行洗錢。”(U.Today)[2021/4/16 20:25:12]
這就要求Geth客戶端和開發團隊絕對不能犯錯。
因此,第一問的答案是:
因為以太坊網絡的客戶端缺乏足夠的多樣性。
值得一提的是,客戶端多樣化不會突然將客戶端開發變成一項輕松的工作。但客戶端多樣性本身依然是一個值得探索的領域,有助于我們找到提高客戶端開發的效益,同時減輕開發團隊負擔的方法。不可否認的一點是,只在Geth團隊上下功夫不太可能解決這個問題。
第二問:為什么以太坊網絡缺乏客戶端多樣性?
BMEX行情觀點:較大周期都沒有頂部跡象,任何一個低點,都是做多的機會。:BMEX行情分析欄目數字貨幣分析師PONY楊表示:ETH最大有一個1小時頂部,不考慮幣種不同步的的影響,存在做空依據,如果空單開在了ETH上,并且在成本價或者新高離場,這個操作就算正確,只不過是一單不賺錢的正確操作而已,對這筆空單來講,最有價值的操作,是對止損的執行。目前來講,較大周期都沒有頂部跡象了,趨勢也依然向上,策略非常明確,任何一個低點,都是做多機會。[2021/3/9 18:27:49]
以太坊主網上線時,我們有多個客戶端。其中最主要的兩個是Geth和CPPEthereum。之后又出現了Parity,CPPEthereum被淘汰。
從那時起,除了Parity之外,沒有一個客戶端能獲得較大的市場份額。去年,Nethermind異軍突起,成為了一顆冉冉上升的新星,但是目前只占據了1%的市場份額。最近,由于Parity遭遇了一些波折,前途一片黯淡,Parity的市場份額大幅下降。我們認為,在理想情況下,以太坊網絡需要有3個及以上的客戶端、每個客戶端占有的客戶端份額都不至于太高、沒有任何一個客戶端能占據遠遠超過51%市場份額。雖然在理想情況下應該實現客戶端多元化,但是我們已經習慣了客戶端霸權的局面。
觀點:對比特幣的普遍看跌情緒是一個底部指標:1月27日消息,加密策略師Smart Contracter表示,比特幣即將重新開啟牛市漲勢。隨著買家繼續維持3萬美元的支撐水平,比特幣將開始升溫。他還補充稱,對比特幣的普遍看跌情緒是一個底部指標。(The Daily Hodl)[2021/1/27 21:47:12]
那么,我們為什么需要多個客戶端?
從我個人的經驗角度來看,構建以太坊客戶端難比登天。Geth之所以能在以太坊網絡上穩定運行,是因為它引入了很多復雜的優化。Geth團隊花費了數年時間才達到了如此高的復雜度,目前仍在繼續優化中。
有人可能會立即建議我們想辦法為落后的客戶端提供支持和幫助。我很警惕這種“人月神話”式的解決方案——在軟件開發過程中,讓更多工程師來解決一個難題很少會成功,而且我不指望這種方案會取得成功。
相反,我認為應該將關注點放在復雜性上。
注:人月神話,mythicalman-month,指出以大量人員和較短的時間,并不能縮短軟件的開發進度。一窩蜂的作業方式無助于軟件生產,且會制造麻煩,產生出更差的軟件。向進度落后的項目追加人力,只會使進度更加落后。
觀點:美國大選加密捐款接受率有所上升 但仍面臨質疑:根據公共誠信中心在2018年的報告,2017-2018年選舉周期記錄了向9名聯邦候選人、政黨和超級行動委員會提供的近57萬美元加密貨幣捐款。雖然令人鼓舞,但這只是很小的數字,因為該選舉周期籌集25億美元捐款。調查反映出,越來越多人接受加密貨幣作為捐款的工具,越來越多美國公民更愿意使用數字貨幣捐款,或者使用美元和加密貨幣組合。雖然接受率有所上升,但為捐贈者提供加密貨幣捐贈選擇的人物數量并沒有相應上升。在2020大選中,只有楊安澤(已宣布退出大選)接受加密捐贈。很多人都強烈指責楊安澤用這樣的營銷策略迎合硅谷選票庫。但Nash.io聯合創始人FabioCanesin表示,“加密貨幣是互聯網原生貨幣。在社交網絡時代,如果你能接觸到公眾,這是強大的融資渠道。所以我不認為這只是一個營銷策略。”接受加密捐贈并不像很多人想象的那么容易。希望用加密貨幣為楊安澤競選捐款的個人必須與競選合規代表通話15分鐘,以便確保捐贈者是有資格投票的美國居民。另外,根據Clovr的調查,針對提問“家會利用更寬松的加密捐贈法規嗎?”,64%的受訪者選擇“是”。[2020/4/28]
第三問:為什么構建以太坊客戶端會這么難?
聲音 | 觀點:阿里影業利用區塊鏈平臺發片是很好的嘗試:微博大V“區塊鏈威廉”今日發文稱,阿里巴巴影業與紐約去中心化娛樂平臺Breaker簽署協議,利用其區塊鏈平臺在海外發行新片 “Striding into the Wind”,這是區塊鏈在電影行業的一次不錯的嘗試,例如電影所有權的Token化,可能會從根本上改變電影融資。就目前的情況來看,電影融資通常局限于少數高財富投資者,但通過Token化,小投資者或許也可以從電影的成功中受益。[2019/11/23]
現在,我們正越來越接近問題的根源。
事實證明,大部分困難都來自于組網協議,即以太坊客戶端軟件用于相互連接并分享區塊鏈信息的那一組工具。以太坊的組網規則,最終影響甚至決定了以太坊客戶端的設計和要求。
一些組網工具指定了未經優化的架構,甚至要求以太坊客戶端運行不必要的功能。客戶端開發者需要在這些限制下工作。
第四問:為什么網絡互聯協議提高了客戶端實現的難度?
我相信,這個問題的答案基本上可以分為兩個部分。
狀態管理
整體網絡互聯要求
就狀態管理而言,以太坊客戶端必需能夠同步網絡上的完整狀態,并維護該狀態的本地副本。這兩點都很難做到。對客戶端以及讀取并處理狀態要求的服務器來說,同步狀態需要提出數百萬個請求,并且會導致磁盤I/O飽和。新同步的狀態需要經過維護和刪減,以便數據庫能足夠快地執行新區塊。從工程上來說,這是一項嚴峻挑戰!
GetNodeData是我們用來同步狀態的唯一網絡互聯工具,針對特定的狀態數據庫格式進行了優化。由?TurboGeth?推廣的“扁平式”數據庫布局在狀態維護方面具有極大的性能優勢,但是使用這種布局會加大?GetNodeData?請求的處理難度。
一旦我們將注意力轉向網絡技術,尤其是DevP2P?ETH?協議,我們會發現還有其他因素提高了客戶端的復雜性。要想加入這個網絡,客戶端需要具備以下能力:
處理訪問最近區塊所生成的狀態的?GetNodeData?請求;
處理訪問鏈上數據歷史記錄的請求,包括區塊頭、區塊體和收據。
從根本上來說,對于許多客戶端操作而言,處理這些請求所需的基礎數據不是必需的,但是現在卻強制它們支持這些功能。這就需要所有客戶端在除了滿足自己本身的需求之外,還要另外構建大量功能。例如,主要作為交易發送網關的客戶端并不需要歷史鏈上數據,可能只需要一個很小的狀態子集。但是,就當前的以太坊版本而言,客戶端依然需要保存完整的副本。
第五問:為什么……
看來我只問了四個“為什么”就找到了根本原因。以太坊協議還沒有完全成熟。在設計以太坊協議時,我們并沒有意識到現如今發現的大多數問題,或者因為當時狀態規模較小、發展歷史較短,這些問題還不成問題。
解決方案
過去一整年,我都在關注這個問題。令我震驚的是,以太坊上許多問題的根源其實都可以追溯到網絡層。
或許最明顯的例子是,磁盤I/O歷來都是客戶端的一個瓶頸。這個瓶頸之所以存在,是因為客戶端傾向于使用樹結構的樸素表示來執行其狀態數據庫。狀態數據庫的構建方式由?GetNodeData?網絡元件決定。
為了解決這個問題,我們需要對以太坊共識層以及網絡層的各個部分進行檢修。目前,檢修工作已經啟動。大量工作已經在Alexey和我共同領導了8個月的“無狀態以太坊”名義下開展。我們所做的一些工作至少減輕了Geth團隊的負擔,因為他們用上自己開發了經年之久的SNAP同步協議。還有一部分工作需要深入理解這個問題并想到可行方案的才俊來承擔。
目前,這樣一個龐大的DevP2P?ETH?協議尚未完全解構。我們對于如何將這個網絡拆分成三個獨立的專用網絡有了基礎了解,但是目前還沒有人直接著手這塊。
另外,還有像?re-genesis?之類的想法,提供了完全回避這些問題的機制。這是一種激進的方法,如果能成功的話,或將為我們帶來很大的優勢。
首先,我們應該清楚的是,以太坊網絡還有許多艱巨的任務需要完成,只有少數人能夠勝任這些任務。雖然每天都有越來越多的開發者參與進來,但是他們需要投入時間和精力來學習必備技能。客戶端開發者在專注于解決日常用戶看不到的底層問題時,還要抽出時間來開發新的EVM功能。
如果我們希望以太坊網絡能夠取得長遠的成功,我認為整個社區都要就解決這些問題展開合作,給予其根本原因足夠的關注和討論。最重要的是,我們要攜手打造出有效的技術解決方案。
原文鏈接:?https://snakecharmers.ethereum.org/applying-the-five-whys-to-the-client-diversity-problem/作者:?PiperMerriam翻譯&校對:?閔敏&阿劍
在7月初,Telegram宣布將停止對Telegram開放網絡的測試網絡的支持,這似乎是Telegram永久退出其區塊鏈項目的又一個跡象.
1900/1/1 0:00:00作者:張烽,原題《數字治理之謎》 一、數字治理基本概念 數字治理是數字技術、數字經濟發展而產生的新型治理.
1900/1/1 0:00:00人生發財靠康波。 這幾天,國內的股票市場非常火熱。一篇由已故的前中信建投首席經濟學家周金濤參與編寫的《繁榮的起點并非沸騰的年代》策略報告在多個微信群瘋傳.
1900/1/1 0:00:00加密市場周期四季分明,幾乎所有人都知道,然而在漫長的熊市周期里卻不是所有人都能熬得住,在類似312這種極端事件中,也不是所有人都能扛得住,許多人即便相信也許還有未來,還是選擇了無奈的離場.
1900/1/1 0:00:00作者:CertiK 假如中國移動或者電信有一天被黑了,那么一定會成為現代版的世界末日……你的第一反應會不會是,網絡沒有了,信號全無了,基本就屬于與世隔絕了.
1900/1/1 0:00:00盡管監管機構需要更多時間,但比特幣ETF最終可能會獲得加密市場的批準。在7月15日的采訪中,灰度投資的董事總經理MichaelSonnenshein告訴摩根溪聯合創始人AnthonyPompli.
1900/1/1 0:00:00