以太坊價格 以太坊價格
Ctrl+D 以太坊價格
ads

以太坊:金色觀察 | 實操:從硬件到軟件 如何在家中運行一個以太坊節點

Author:

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

文/Alex R. Mead,CoinMetrics

在消費級硬件上輕松設置并運行以太坊節點的能力是以太坊網絡去中心化特性的一個關鍵賣點。但是對于一般人來說,在家里設置并運行一個節點到底有多大實用性?隨著合并的完成,這個問題在加密社區中被頻繁提及。在Coin Metrics,我們向來都是直接探索節點,獲得一手體驗。

在本周“網絡狀態”系列文章中,我們將介紹在家里設置和運行以太坊節點所需的步驟。 我們將從基本硬件和網絡需求開始,接著介紹軟件下載/編譯/安裝,最后介紹節點操作步驟和維護。 在整個過程中,我們將提供從運行Geth/Lighthouse節點中獲得的經驗見解,Coin Metrics團隊自2022年6月以來一直在持續運行該節點。

請注意,本文不構成Coin Metrics對任何特定硬件、互聯網服務提供商或以太坊客戶端的背書,也不構成任何工程或財務建議。 所討論的節點獨立于Coin Metrics基礎設施運行,與Coin Metrics并無關聯,純粹是出于實驗和研究目的,與Coin Metrics服務沒有任何交互。本文所提供的信息單純是為了讓我們講得清楚,讓你看得明白。所以,開始吧!

計算機

要開始設置和運行你自己的以太坊節點,你需要一臺計算機及互聯網連接。 計算機需要滿足兩個一般要求,足夠的RAM和足夠的硬盤空間。

每個節點客戶端都有特定的RAM要求(見下文),但任何一臺16GB RAM的現代計算機基本都夠用。節點也可以運行在8GB的RAM上;然而,如果你想使用該節點做點什么,而不只是口頭上說說“我要運行一個以太坊節點”而已,那么你可能會希望你有一臺16GB RAM的計算機。 建議在專用的計算機上運行以太坊節點,也就是說該計算機的唯一用途就是運行以太坊節點。 沒有流媒體Netflix,不編輯視頻,也不處理其他前端/后端進程,只用于運行你的節點。

金色午報 | 2月11日午間重要動態一覽:7:00-12:00關鍵詞:Voice、Poloniex、挖礦難度、Coinbase冷錢包、北斗

1. 國家發改委涂圣偉:加快區塊鏈等現代技術在農業領域的應用。

2. 美國白宮2021年預算提案:建議特勤局轉移到財政部之下,以調查加密貨幣犯罪案件。

3. Voice官方:測試版將首先在美國推廣。

4. Poloniex因軟件問題導致“錯誤執行”,取消了12分鐘內所有交易。

5. 比特幣挖礦難度將上調0.61%至15.56T,創歷史新高。

6. Coinbase冷錢包比特幣存量即將突破一百萬。

7. 北斗系統新聞發言人:區塊鏈等技術離不開北斗,也離不開5G。

8. 聯想集團董事長楊元慶:疫情造就獨特消費環境,區塊鏈等企業會迎來發展。

9. 光大銀行鄭州分行推出福費廷區塊鏈交易平臺等線上服務。

10. BTC現報9741美元,近24小時下跌3.46%,市值為1772.70億美元。[2020/2/11]

然后,你需要確保你的計算機有足夠的硬盤空間來存儲當前的以太坊區塊鏈(記住,合并后,以太坊區塊鏈現在有兩個部分:執行層和共識層信標鏈),而且還要有合理的空間來維持鏈的增長。就目前而言,一個比較好的經驗就是使用2TB的固態硬盤(SSD)。固態硬盤是必不可少的,因為它支持足夠快的讀寫行為,因此節點可以本地同步當前鏈,并在鏈持續增長時維護鏈。

至于我們的節點,我們運行的是裝有16GB RAM的Dell OptiPlex 5080和英特爾酷睿i7處理器。 這臺設備是直接從戴爾的網站上購買的“現貨”。此外,為了擴充內置硬盤空間,我們還使用USB-C Type 3連接器(這款USB連接器是藍色的)連接了一個2TB的三星T7便攜式固態硬盤。

金色晨訊 | 德國內閣和央行就CBDC問題進行密切溝通:1.BTC算力創歷史新高。

2.德國內閣和央行就CBDC問題進行密切溝通。

3.V神:現在不是提高gas limit的最佳時機,建議在伊斯坦布爾硬分叉時進行。

4.歐盟競爭事務專員:歐盟委員會已經向市場發送有關Libra的調查問卷。

5.目前比特幣礦工的總營收已超過140億美元。

6.印度黑錢特別調查組:政府沒必要對加密貨幣進行監管,一刀切是唯一選擇。

7.韓國互聯網巨頭Kakao正在開發4個加密錢包 其中一個類似于三星區塊鏈錢包。

8.ETH、ADA和DASH等有超過80%的地址處于虧損狀態。

9.Elwood Asset Management將推出10億美元的機構加密對沖基金。[2019/8/31]

以太坊節點:Dell OptiPlex 5080,有線以太網連接,2TB固態硬盤

網絡連接

要與以太坊網絡同步,你需要至少每秒25MB的下載速度,這是大多數家用互聯網都能滿足的規格。 對于我們的節點,我們使用美國中西部可用的標準的Comcast計劃,據稱下載速度為250MB/秒,總數據下載上限為每月1.2TB(超出后將收取額外費用)。這個服務包,或類似的服務,通常面向位于發達經濟體大都市地區的用戶。

合并后,所有以太坊節點必須同時運行兩個軟件,一個共識層節點和一個執行層節點。 Ethereum.org列出了以下執行層節點:Geth、Nethermind、Besu、Erigon和Akula。對于共識層節點,則列出了:Lighthouse、Lodestar、Nimbus、Prysm和Teku。

對這些不同軟件的分析本文不做贅述。不用說,我們決定分別為我們的執行層和共識層運行一直可靠的Geth和受人尊敬的Lighthouse。

分析 | 金色盤面:XRP強勢反彈 短線有調整需求:金色盤面綜合分析:XRP先于市場見底,走出一波強勢反彈,從形態看屬于5浪走勢,目前處于4浪整理,短線承壓,可密切關注,但市場整體處于弱勢,請投資者做好風控。[2018/9/7]

操作系統(OS)

在深入研究運行以太坊協議的軟件之前,先簡單介紹一下操作系統的選擇。我們決定運行Ubuntu 22.04 LTS,裸金屬版。 裸金屬意味著操作系統直接運行在處理器的硅片上。 沒有虛擬機,沒有Docker容器,只有計算機上的“老式”操作系統。 在裸金屬上運行可對硬件資源進行最佳利用,不需要虛擬化的“開銷”。Ubuntu 22.04 LTS可免費下載,之所以選擇它還有部分原因是因為加密技術和Linux社區都具有獨立性,其中,Ubuntu是若干“Linux風格”系統之一。

要在戴爾電腦上安裝Ubuntu操作系統,我們必須對運行Windows 10的現有硬盤進行開箱分區。 這個過程的詳細說明可在Ubuntu的網頁上找到,需要一個USB驅動器在新分區上加載新的操作系統。 安裝操作系統可能很棘手,可能是非技術節點操作者要克服的第一個真正的“瓶頸”。應該注意的是,可以在Windows 10上運行相同的系統,因此這不是真正必要的步驟。 此外,互聯網上有很多資源可以解決這個問題,所以我們認為,一個有動力并有良好計算機技能的用戶要完成這個任務仍然是合理的。

執行層:Geth

根據clientdiversity.org的數據顯示,Geth是目前使用最多的以太坊節點,約占所有以太坊客戶端的80%。 雖然這對于網絡來說并不理想,但這是我們的節點正在運行的客戶端。 至于我們的客戶端可執行程序(例如,當你啟動節點時我們的操作系統實際運行的程序)——以一種真正的“不輕信,去驗證”的方式——我們想要確定軟件的組成。因此,我們使用Git從官方的Go Ethereum源碼庫下載了源代碼。 在代碼庫完全本地化的情況下,我們使用GNU Make構建Geth客戶端,還使用了來自Go Ethereum的其他幾個支持軟件,包括使用clef為節點創建和管理key-pair對。Go Ethereum的網頁對每一步操作都有詳細說明。

金色財經現場報道 EosStore發起人陸海峰:以用戶為中心做生態增值:金色財經現場報道,在EosStore競選超級節點暨“柚子資本發布會”上,EosStore發起人陸海峰在現場演講中指出:“EOS本身是商業應用的操作系統,我們認為很多商業化應用都會在EOS生態系統中落地。我們正在以用戶為核心,做生態的增值、參與、貢獻;如果只將資金用于分紅方面,那么這個節點本身可能不能更好的保證技術開發,在社區方面,EosStore正在從咨詢、活動、學院、投票福利、技術開發、投資回報等多個角度著手推進。”[2018/5/13]

下載源代碼,并對其進行編譯,再將它安裝到你的設備上,這是真正的軟件工程師類型的工作。 很可能,這對普通計算機用戶來說是一個難以達到的提升。因此,如果從源代碼編譯太過困難,Geth還提供了預構建的二進制文件,你可以從他們的網頁下載。 但是,請注意,雖然這些二進制文件非常值得信任,但實際上你信任的是它們的組成。使用源代碼方法,可以單獨分析每一行代碼,因此不需要信任。

共識層:Lighthouse

本著與Geth相同的精神,對于節點,我們從官方Lighthouse庫下載了Lighthouse,它是從源代碼編譯的。與Geth類似,如果沒有軟件經驗,編譯Lighthouse可能非常棘手。 因此,預構建的二進制文件也可用于Lighthouse。

運行節點

在實際運行節點時,請記住操作者必須在同一臺機器上運行兩個程序(執行客戶端、共識客戶端)——在我們的例子中分別是Geth和Lighthouse。 此外,每個客戶端都需要向硬盤寫入大量數據,這就引出了我們的第一步,為文件系統安裝固態硬盤。

安裝固態硬盤

與編譯源代碼類似,定位物理固態硬盤驅動器然后進行“安裝”對普通計算機用戶來說并不容易。需要使用終端程序并具有在計算機的層層文件夾結構中暢通無阻的能力。 對于我們的節點,我們選擇將固態硬盤安裝到主目錄文件夾~/ethereum下。在這個文件夾中(請記住,它實際上位于固態硬盤上!)我們創建了另外兩個文件夾,~/ethereum/execution_layer和~/Ethereum/consensus_layer。這些文件夾(或者程序員稱之為目錄)將保存節點所需的所有文件,包括區塊鏈本身。

金色財經獨家分析 巴基斯坦所謂“建議”不交易加密貨幣實則監管收緊:巴基斯坦國家銀行近期發布聲明,澄清了銀行在加密貨幣上的立場。該聲明表示,以防公眾和機構遭受經濟損失、被非法交易牽連,“建議”公眾和機構不要交易這些貨幣,并非完全表示禁止加密貨幣。金色財經獨家分析,雖然巴基斯國家銀行在今日做出了補充說明,“建議”公眾和機構不要交易這些貨幣,但是從之前的報道中可以看出,巴基斯坦國家銀行在聲明中的原話是,“所有銀行、DFIs、小額信貸銀行和支付系統運營商(PSOs)、支付服務提供商(PSPs)建議避免處理、使用、交易、持有、轉移價值、促進和投資加密貨幣、Token。此外,銀行、DFIs、小額信貸銀行和PSOs、PSPs不能幫助其客戶或賬戶持有人在風投或ICO的環境下進行Token交易。一旦發生以上提到的任何交易應立即報告金融監管部門(FMU)作為可疑交易。”也就是表明巴基斯坦對于加密貨幣的監管是趨嚴的,一旦發生相關交易需要向監管部門報備,這對于加密貨幣行業的發展而言無疑是有限制的,與“禁止”只有一線之隔。幾乎在同一時間,印度儲備銀行(RBI)也做出了同樣的監管策略,印度儲備銀行正式命令所有受監管的實體停止向涉及加密貨幣交易的任何企業和所有企業提供服務。[2018/4/9]

運行節點軟件

有了節點運行的文件位置,我們現在可以運行節點軟件了。我們首先遵循Go Ethereum網頁上的步驟,包括使用clef設置一個用戶帳戶((EOA -- 外部擁有的帳戶),然后使用幾個參數啟動geth,最重要的是將datadir設置為我們在固態硬盤上的~/ethereum/execution_layer文件夾(即目錄)。請注意,chainid為“1”(不帶引號)表示主網(即我們所知道和熱愛的真正的以太坊,而不是測試網)。此外,現在geth必須連接到共識層客戶端(在我們的例子中是Lighthouse),必須配置一些額外的參數,Go Ethereum在他們的網頁中相應的“Connecting to Consensus Clients”(連接到共識客戶端)內容中對這些參數進行了解釋。

該命令將啟動主網區塊鏈的同步進程,到目前為止,有超過600GB的資源(2022年10月)。當我們在2022年6月啟動最初的節點同步時,這個過程用了大約5天時間。

共識層客戶端Lighthouse的運行方式與上述Geth相同。 同樣,請確保向固態硬盤正確指定datadir,以確保有足夠的硬盤空間來存儲所有所需的數據。此外,Lighthouse需要與Geth進行通信,因為他們都支持合并后的以太坊。關于連接到執行引擎,Lighthouse文檔提供了關于此連接過程的具體說明。 我們的節點同步信標鏈花費了大約兩天時間。 請注意,我們首先同步了主網鏈(即Geth),然后啟動了信標鏈(即Lighthouse)同步。

以太坊節點:左屏為Lighthouse STDOUT,右屏為Geth STDOUT。

當節點同步時,會下載大量數據。實際上是以太坊的整個區塊鏈歷史被復制到你的本地計算機上,包括信標鏈。這些信息完全下載結束后,你可以查詢本地節點的任何信息,并且不要信任任何人來驗證該以太坊系統。有了這樣的設置,當涉及到以太坊網絡和所有與之相關的DAapp時,你就可以真正做到“不輕信,去驗證”了。

連接到你的節點很簡單,可以為Geth或Lighthouse節點組件使用本地托管的RPC。這些API在執行層和共識層都有很好的文檔記錄。對于Python用戶來說,使用開源的Web3.py模塊是一個很好的選擇,有很多博客文章和問題論壇的回答免費提供了許多示例,比如Stack Overflow。如果你對API并不熟悉,你會經歷一個學習曲線;然而,有了Python和這個生態系統可用的大量資源,有動力的用戶當然也可以在網上找到資源來學習他們需要的一切知識技能。

節點表現

隨著權益證明(PoS)成為共識機制,以太坊的區塊時間的可預測性大為提高。出塊時間高度一致,為每12秒產生一個區塊(對于漏塊來說則為24秒、36秒,等等),其他通信(例如,證明)在區塊傳播中為每6秒一次。運行一個專用節點(即,計算機只運行以太坊),這在下面顯示的CPU和網絡活動監視器中都非常清楚。這正是我們所期望的,而且系統的“理論”與觀測到的數據相匹配總是一個令人安心的跡象。回想一下我們自己的節點,是從源代碼編譯的,并使用所有基本構建塊進行設置。

以太坊節點:標準操作的CPU負載百分比和網絡數據速率。

為了進一步顯示正在運行的節點,我們為共識層調用一個端點來返回所有驗證節點的集合(例如,/eth/v1/beacon/states/{state_id}/validators),這是在編寫本文時超過400,000個驗證節點的結果。該查詢的運行時間為幾分鐘,如下所示,在請求處理期間,CPU的使用率明顯增加,然后在請求得到回復后又回落到“正常”狀態。

以太坊節點:信標節點響應API調用,然后恢復正常的節點操作負載。

持續節點運行

與所有軟件系統一樣,會不斷開發新的版本。對于Geth和Lighthouse來說,也是如此——而且,你必須時不時地更新節點軟件。對我們來說,這包括從Github庫中提取最新版本,編譯新的可執行文件,并使用最新的穩定版本重新啟動Geth和Lighthouse。對于我們的簡單節點,我們只需重新編譯并重新啟動。對于面向生產的節點來說,更適合部署一個開發、分階段和完全監控的生產環境。如果你不親自編譯,可以下載最新的預編譯二進制文件,并使用它們重新啟動節點。此外,操作系統也有必須下載和安裝的更新。這對于避免操作系統級別的安全問題尤其重要。

對于我們的節點來說,首先需要一個學習曲線來讓節點連續運行。管理每個進程的RAM利用率是第一個障礙,因為在沒有足夠RAM的情況下,計算機會“隨機”關閉。此外,最初節點使用的是WiFi,無線路由器由于數據過載而崩潰。解決了這些問題(即緩存限制和有線以太網)后,該節點已經連續運行了幾個月沒有停機了。

使用消費級計算機硬件和家庭互聯網連接,可以運行自己的本地以太坊節點。雖然運行從源代碼本地編譯的客戶端(共識層和執行層)對大多數用戶來說可能很困難,但對于最常用的客戶端來說,可以使用預編譯的可執行程序。此外,安裝一個固態硬盤來存儲區塊鏈并運行操作系統(OS)對大多數用戶來說是一個挑戰;但一個有動力、有耐心、愿意學習的用戶是完全有能力做到這些的。

節點操作者的下一步是決定是否成為驗證者。為此,節點必須在本地運行第三個客戶端(Lighthouse還附帶一個驗證者客戶端),并且必須質押32個ETH。這比節點設置要稍微復雜一些。此外,人們應該對離線懲罰以及搞砸質押的以太幣私鑰可能帶來的風險有所了解。因此,用戶應該在運行驗證者節點之前了解自己在做什么。我們還沒有自己運行驗證者節點,但是鑒于我們運行自己節點的復雜性,你最好至少在運行自己節點的一個月后,再決定是否運行你自己的驗證者節點。

寧哥的web3筆記

金色財經 龐鄴

DoraFactory

金色財經Maxwell

新浪VR-

Foresight News

Footprint

元宇宙之道

Beosin

SmartDeerCareer

Tags:ETH以太坊GHTLIGHThttps://etherscan.io以太坊官網入口nSights DeFi TraderMOONLIGHT幣

比特幣價格實時行情
FUR:Infura 如何逐步實現去中心化

Infura 是以太網絡 API 的重要接口,開發者通過 Infura 可實現一鍵接入以太坊。Infura 和 MetaMask 都是由以太坊基礎設施公司 ConsenSys 推出.

1900/1/1 0:00:00
COIN:一文概覽Web3增長工具賽道全景

加密市場雖然處于熊市,但 Web3 增長工具市場正在不斷升溫,這里有一份 Web3 增長工具清單請查收.

1900/1/1 0:00:00
BTC:金色早報 | 伊朗比特幣倡導者Ziya Sadr被伊朗安全部隊逮捕

▌伊朗比特幣倡導者Ziya Sadr被伊朗安全部隊逮捕金色財經報道,據多個消息來源稱,伊朗的比特幣倡導者Ziya Sadr上個月被伊朗安全部隊逮捕.

1900/1/1 0:00:00
OIN:幣安棄購 FTX 80 億美元虧空重創幣圈

北京時間11月10日凌晨,幣安官宣放棄收購陷入危機的競爭對手 FTX, 30歲Sam Bankman-Fried (SBF)締造的加密帝國再度"命懸一線".

1900/1/1 0:00:00
DAS:穿越山谷的英偉達 會成為元宇宙最重要的基礎設施嗎?

編者按:人們往往會用波峰和波谷來形容股票的走勢。但是往往卻會忽視最重要的時間維度。從短期看,你也許能分出明顯的波峰波谷,但如果再放眼到更長的時間維度,過去站在最高點的波峰,也不過是站在未來最低點.

1900/1/1 0:00:00
數字貨幣:區塊鏈技術發展趨勢與銀行業探索實踐

在數字化轉型的大背景下,全球主要國家都在加快布局區塊鏈技術,搶占新一輪創新變革的高地。 一、區塊鏈技術概述 技術特征 區塊鏈技術是密碼學、共識算法、P2P通信、智能合約等多種技術的集成創新,打造.

1900/1/1 0:00:00
ads