以太坊交易所 以太坊交易所
Ctrl+D 以太坊交易所
ads

Beam Sync:同步以太坊節點的新方法_TRI:BEAM

Author:

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

編者按:本文來自:以太坊愛好者,作者:JasonCarver,翻譯&校對:陳亮&阿劍,Odaily星球日報經授權轉載。為什么要改善節點同步體驗?每當我想起目前還有多少人仍在使用Infura與鏈上應用程序交互時,我就感到有點難受。Infura的服務很棒,但如果大部分用戶都不自己運行節點,顯然也不太對頭。即使是非常有能力且積極性非常高的開發人員,也不能完全擺脫對Infura的依賴。從這點看來,我們仍未完成以太坊的“自主驗證”愿景中的重要部分。我們的團隊希望盡自己的力量扭轉這一趨勢。我們的使命是盡可能增加網絡上的節點數量,特別是那些由愛好者、研究人員和開發人員運行的節點。當我們問起他們為何不運行自己節點時,答案不外乎是:“我安裝了客戶端軟件,也嘗試了同步區塊鏈,但好像總是同步不上。于是我就停下來了,因為我還有別的事要做。”所以,如果我們想讓更多的人來運行節點,就得讓節點同步更快一些,并且在同步過程中能夠反饋進度信息。許多團隊都在這個領域耕耘。專用硬件或許是一條重要途徑。但在這篇文章里,我們想講的是“BeamSync”同步方法如何能夠大幅提升同步速度。現有的同步方法

為了更好地理解BeamSync的原理,我們先來看看現有的幾種同步方法。FullSync

完全同步方法是執行自創世區塊以來的每一個區塊。創世區塊標志著一個起始創世狀態。所謂“執行區塊”就是,每下載到一個區塊,就讀取前一個狀態并產生新狀態,并以該新狀態來驗證區塊頭中的狀態根。在以太坊主網上完全同步的速度非常慢,而且隨著網絡的老化,使用完全同步方法來同步到最新區塊的時間也會越來越長。所以人們開發出了“快速同步”方法。FastSync

Boss Beauties將在聯合國舉辦Boss Beauty Role Models NFT展覽:2月11日消息,Boss Beauties近日宣布將在聯合國舉辦一項活動,展示其限量版1/1 NFT藝術收藏品Boss Beauty Role Models。該收藏品是在聯合國展出的第一批NFT藝術藏品。Role Models系列是與元宇宙教母Cathy Hackl合作創作。

通過與5th Element Group的合作,該活動將于2022年3月8日舉行。5th Element Group是一家全球影響力咨詢公司,它直接與聯合國伙伴關系辦公室合作,將公共組織、私營組織和非營利組織聯系起來,以共同實現聯合國的17個可持續發展目標。現場直播活動將包括Boss Beauty Role Models系列的完整展覽,以及來自知名品牌、公司和影響者的主題演講和小組討論。

據悉,Boss Beauties是一項由女性領導的全球倡議,旨在通過前沿合作為女孩和婦女創造機會。限量版1/1 Historic Boss Beauty Role Models將于3月7日通過慈善拍賣出售。募集的資金將通過非營利組織My Social Canvas用于支持Boss Beauties婦女和女孩獎學金基金。(PRNewswire)[2022/2/11 9:45:40]

快速同步方法就是下載過去所有的區塊和區塊頭,并選擇最近的區塊作為“啟動塊”。啟動塊以前的區塊都跳過執行,到了啟動塊再開始執行區塊。這種方法假設了從創世塊到啟動塊都正確地遵循了所有EVM規則。這個假設是合理的,因為礦工有動力遵循誠信不作惡原則,生產正常區塊,拒絕可能具有攻擊性的區塊。在快速同步可以執行啟動塊之前,需要的區塊狀態包括:合約字節碼、帳戶和合約存儲內容。執行交易時可能需要讀取所有這些值中的任何一個。因此,快速同步方法要求從其他對等節點處獲得啟動塊之前的狀態快照。快照是用狀態根哈希值來標記的;所謂狀態根哈希值,就是所有狀態內容的哈希默克爾樹根值。節點使用該狀態根哈希來驗證從其他對等節點處下載的狀態數據是否與礦工在該區塊中聲明的狀態相匹配。快速同步方法下載完所需的所有狀態后,等于節點已經有了執行交易所需的一切數據。那么這時候開始,節點就可以切換成完全同步模式了,從啟動塊開始可以逐個逐個執行區塊了,就跟完成了啟動塊以前的完全同步過程的節點一樣。簡化之后的過程就像下面這張動圖所顯示的:

PhantaBear NFT市值突破1000萬美元:1月5日,據NFTGO數據顯示,“PhantaBear”NFT市值突破1000萬美元,目前為1073萬美元,24小時漲幅22.53%。本文撰寫時,“PhantaBear”NFT交易總額達到1394萬美元,當前地板價為0.69 ETH。1月3日,杰威爾音樂公司曾發布聲明稱“PhantaBear”商業行為與周杰倫無關亦不是周杰倫推出NFT,但周杰倫隨后將其Instagram頭像更換為PhantaBear NFT作品。[2022/1/5 8:26:17]

其他方法

其他的快速同步方法包括WarpSync以及一些目前尚未得到驗證的同步方法。抽象一些來看,它們都屬于快速同步方法的不同形式。另外,即使了解這些其它同步方法的原理,也無助于理解Beam同步策略,所以這些同步原理不是我們這篇文章的重點,我以后再講。快速同步方法有多快?

快速同步方法在目前的主網運行環境下面臨一些挑戰,因為同步需要下載很多數據,甚至超過100GB的數據,所以,可能在上圖所示的第二步“GetAllState”就要卡住很長時間。更糟糕的是,對等節點不會逐塊給你提供狀態數據,只會提供啟動塊前一段時間內的狀態,比如啟動塊前100個區塊的狀態數據。Geth客戶端的默認設置是前120個區塊。如果你不能在30分鐘內下載完所有的狀態數據,你就需要做切換,就是換一個新的啟動塊,重新開始同步,雖然不是從0開始,但是也增加了下載和驗證區塊的時間。Geth客戶端在提高同步速度上取得了非凡的成績,快速同步和完全同步模式都有巨大進步,而且Geth客戶端的每一次更新都會有所推進,但即使你有非常完美的電腦硬件,同步過程依然需要持續至少4小時。對于第一次同步來說,這樣的過程確實略顯艱難。那么,我們團隊正在開發一個用Python語言編寫的客戶端,叫“Trinity”。Python在速度性能上不會比Go語言更快。如果以性能為中心的Geth代碼不能像我們希望的那樣快速同步,Trinity客戶端又有什么機會呢?完全有理由預計Trinity客戶端執行一次快速同步需要幾個星期。但是如果客戶端不能同步主網,那么它就沒意義,同樣,花費幾周時間去同步也沒有意義。出于這種需要,我們構思了一種新的同步策略,我們現在稱之為:Beam同步方法。Beam同步方法

Moonbeam Network將測試網升級至Moonbase Alpha v7:金色財經報道,Polkadot上與以太坊兼容的智能合約平臺Moonbeam Network官方發文宣布,已推出測試網最新版本Moonbase Alpha v7。此版本改善了開發者體驗,并加強了網絡的穩定性和去中心化。這些更新是向推出Moonriver邁出的重要一步,Moonriver預計將在接下來的幾個月內實現。Moonbase Alpha v7升級包括:1.調試和跟蹤API;2.高級區塊瀏覽器支持;3.預資助帳戶獨立開發者節點。該版本還對基礎架構進行了重大改進。現在,Moonbase Alpha已與Polkadot的Rococo v1分支兼容,作為當前Rococo測試環境中的平行鏈,這為Moonbeam注冊打開了大門。其他基礎結構升級還包括對Moonbeam質押功能的改進以及將主動整理器插槽從8個擴展到16個。[2021/4/6 19:48:01]

概述

Beam同步方法是直接改進快速同步方法的結果,這兩種同步方法的區別是Beam同步方法是一開始就直接執行啟動塊,并且只請求本地數據庫中缺少的狀態數據,并把輸入狀態和輸出狀態保存在本地。執行完一個塊后就同步到下一個塊并重復該過程,按需請求缺少的數據。

動態 | Beam發布4.0版桌面錢包,增加原子交換功能:金色財經報道,12月4日,匿名幣項目Beam宣布發布桌面版錢包4.0版本,正式推出原子交換功能(Atomic Swaps),用戶可以在該錢包中直接通過去中心化的方式秘密地進行資產的互換,包括在Beam與BTC、Beam與LTC及Beam與QTUM 之間,并且沒有任何交易對手風險。另外,原子交換市場目前處于測試階段,存在風險,建議用較少金額嘗試。[2019/12/5]

隨著時間的推移,缺少的數據會越來越少。注意,如果某個狀態從未被訪問過,那么客戶端將永遠不會請求它,因此我們在后臺運行另一個進程來填補這些空白。通過該回填過程,Beam同步最終會取得所有狀態數據并保存在本地,然后節點就可以切換到完全同步狀態。我們將執行每個塊所需的數據集稱為“區塊見證數據”。得益于默克爾樹的結構,我們不用完整地下載某個狀態,就可以證明見證數據真的是從這個狀態中取出來的。區塊見證數據大小

為了簡單起見,我們用“區塊見證數據大小”來指稱執行區塊所需的數據元素數量。這類數據元素可能是在主要賬戶狀態樹上的一個節點,或者是合約存儲樹上的一個節點,或者是某個合約的完整字節碼。分析區塊見證數據大小是理解Beam同步方法性能的關鍵。快速同步方法必須在執行第一個區塊之前下載全部狀態數據,而Beam同步僅需要下載一個區塊的見證數據,如果所下載的區塊見證數據包含完整狀態的三分之一,那么Beam同步的運行效率將大約是快速同步的三倍。所以,顯然,下一個步驟是看主網的見證數據實際是多大。可能直接下結論還為時尚早,但是早期試驗結果表明3000個狀態樹節點的數據量是一個合理的估計。而主網的全部狀態信息有超過3億個樹節點。Beam同步的速度提升

動態 | Beam停止出塊近兩個半小時:Beam官方今日在推特表示,區塊停在了25709塊,正在調查原因。據Beam的區塊瀏覽器顯示,Beam的區塊在停止了近兩個半小時后,挖出了25710塊。[2019/1/22]

讓我們新定義一個標準:“從啟動到執行”的時間。這是從用空數據庫啟動節點到完成最近一個區塊的完全導入所需的時間。如果Beam僅需要下載3000個狀態樹節點,而快速同步需要下載3億個樹節點,那么我們就可以確定BeamSync方法的速度上限:在同步主網時,可在“從啟動到執行”時間上獲得最多10萬倍的提升!但是,BeamSync方法往往無法真正做到10萬倍提升。理由包括但不限于:狀態數據的下載并不是建立全節點的所有工作,例如,我們還要下載區塊頭來驗證我們所同步的區塊鏈是最長鏈區塊見證數據是按需確定的,這就意味著我們無法提前預知需要哪些狀態數據。所以我們向對等節點請求數據時,一次只能請求一個狀態數據。相反,快速同步一次最多可請求384個樹節點,這使得Beam同步對對等節點的網絡延遲更敏感。尋找高質量,低延遲的同步節點需要花些時間。說實在的,會遇上什么樣的對等節點,那是真·隨機事件。與快速同步方法不同,Beam同步方法會持續下載啟動塊之后的區塊狀態,這樣也會拖慢區塊導入時間。如果你對這一點有一些直觀認識,那么你可能會注意到,如果收集區塊見證的平均時間比區塊生產的平均時間還要長,那問題會更加嚴重。Beam同步滯后性

獲得第一份區塊見證數據所需的時間必定長于網絡產生一個區塊的時間。同樣,我們也可以預見,見證數據要幾個區塊的時間才能送達,我們把這種情況稱為“滯后”,大約是最新一個導入區塊和鏈頂端區塊之間的時間間隔。區塊見證數據的收集延遲問題可能會逐漸加重,然后你會發現你的Beam同步節點延遲了5分鐘。這就是說,你本地擁有的最新區塊其實是整個網絡5分鐘之前產生的區塊,這意味著當RPC調用你現在節點賬戶余額的時候,你的節點會反饋五分鐘之前的余額。在坊間的測試中,很常見的一個現象是滯后時間變化很大,從1分鐘到20分鐘不等。幸運的是,我們有一些技巧可以使得區塊同步從滯后的情況中恢復,事實上,一般來說,落后越多反而恢復得越好,這就導致了滯后時間的極大波動:先是不斷落后,然后是迅速追趕,循環往復。我們可以在區塊落后的情況下更快地趕上的一個原因是,我們可以提前、同時為多個區塊生成見證數據。畢竟,只有落后時,你才能利用這些未來的區塊。當然,如果收集所需區塊數據的時間總是超過區塊產生時間,那么毫無疑問你將會越來越落后于區塊鏈的增長,我們希望這種情況永遠不會發生,但我們需要為此做好計劃。BeamSyncPivot

就像快速同步一樣,如果你落后太多,對等節點可能就不愿意為你提供你需要的數據了。切換機制是解決這個問題的關鍵。Beam同步里的pivoting機制就像快速同步里的一樣,你的節點選擇一系列要跳過的塊,并在鏈頂端附近選擇一個新的區塊塊區塊頭,然后,Beam同步再一次開始,節點并沒有完全從頭開始同步,它仍然擁有來自上一次同步的所有數據。無論你是采用Beam同步或者快速同步,只要使用切換機制你就需要付出相應的成本,切換機制意味著需要下載更多數據,這些數據中還會有一些你的節點并沒有親自驗證過其執行的區塊。好消息是:如果你不是落后超過30分鐘,Beam同步方法就不需要激活切換機制,相反,使用快速同步方法時,你非得切換幾次不可。好了,讓我們看看真實的情況是什么樣。Trinity客戶端上的Beam同步

原型公布

一個新的阿爾法版本的Trinity客戶端上周公布,這個版本包括一個可在高端硬件上運行的Beam同步方法原型。我們一直在測試針對主網的同步過程。通常可在第一個小時內執行第一個區塊,多數時候都能在5分鐘之內搞定!這里不包括下載區塊頭的時間和偶爾因為缺少好的對等節點所耽誤的時間。注釋:把區塊GasLimit從8M提升到10M似乎會增加平均滯后時間,伊斯坦布爾升級后可能會減少滯后時間,因為提高了在區塊鏈上寫入狀態數據所需的gas耗費量。目前Trinity還是阿爾法版本,最新的版本依然有很多問題,比如同步可能會在一兩天后突然中止,即使沒有中止,也會落后很多導致激活切換機制。安裝Trinity客戶端需要額外的工作,命令行輸出更是一團糟。所以,Trinity目前只準備好了給那些既好奇、又不介意實際操作一下的開發者和研究人員使用。懸而未決的問題基本上都會在日常開發中暴露出來,所以這些問題都是“后臺日志上的bug”。在這一點上,可以說,沒有人擔心BeamSync會不會是一個難以企及的夢想。這種對Beam同步的信心是嶄新的。但我們也認為未來有可能有突發的未知問題亟待解決,就像一個月前一樣!剩下的工作

除了基礎的調試和實現工作,我們依然還有許多其它工作要做。Trinity還沒有實現狀態的回填機制。目前激活切換機制的唯一方法是重新啟動Trinity,而且尚不清楚Beam同步方法所需的最低硬件配置。以上所有問題都處于積極的研發攻克之中,并且這只是Trinity上許多工作之一,感謝以太坊基金會對這些工作的贊助和支持。BeamSync的創新之處在哪里?

Beam同步方法,和其他的理論一樣,都是建立在之前的研究工作之上的。通過下載最新狀態、跳過舊區塊執行來加速同步的方法,并不是我們發明的。依靠見證數據而不是完整狀態來執行區塊,從而加速執行的方法,也不是我們發明的,詳細情況可以看無狀態客戶端。真正的進展是我們綜合了這兩者:首先使用引導式快速同步來模擬無狀態客戶端,然后逐漸過渡到完全同步模式。我們丟掉了無狀態客戶端的一個優點,即低硬盤開銷,但是我們保留了快速執行最近一個塊的優點。通過在本地保存狀態輸入和狀態輸出數據,我們減輕了關于無狀態客戶端的一個重要隱憂,即被大量見證數據DOS攻擊的風險,Beam同步方法執行的時間越長,被DOS攻擊的風險越小。在我們運行以太坊本地客戶端的時候,Beam同步模式可以提供更好的反饋和更快的執行結果,我們覺得這對于用戶愉快地運行本地節點來說是重要的一步。感謝PiperMerriam、BrianCloutier、AlexStokes、VoithMascarenhas和NoelMaersk。

Tags:BEABEAMTrinityTRIBEATLES幣BeamSwapVrtrinityVetri

歐易okex官網
回顧2008年金融危機,做長期主義投資者_VBT:mobius幣什么時候上線

北京時間3月18日晚間,美股開盤再次暴跌。截至寫稿時為止,道瓊斯指數跌幅為6.3%,納斯達克指數跌幅為4.7%,標準普爾500指數跌幅為5.18%.

1900/1/1 0:00:00
數據分析:比特幣能耗驚人,能耗估值超1萬美元/BTC_NFTG:比特幣

摘要:電力消耗指標顯示,比特幣電力消耗呈一年翻倍的速度不斷增長,目前的能耗相當于羅馬尼亞或捷克的電力消耗。基于能耗的估值模型推測,目前的比特幣價格處于嚴重低估的水平.

1900/1/1 0:00:00
行情分析:大盤受均線壓制,短期震蕩偏空_GMT:USDT

本文來自:哈希派,作者:哈希派分析師團隊,星球日報經授權轉發。金色財經合約行情分析 | 資金費率保持高水平,多頭情緒仍濃:據火幣BTC永續合約行情顯示,截至今日18:00(GMT+8),BTC價.

1900/1/1 0:00:00
如何利用門限簽名來生成隨機信標?_BIT:FIN

編者按:本文來自:以太坊愛好者,作者:ALEXANDERSKIDANOV,翻譯&校對:IANLIU&阿劍,Odaily星球日報經授權轉載.

1900/1/1 0:00:00
誰給了孫宇晨“控制”Steem的權利?_STEEM:區塊鏈

編者按:本文來自蜂巢財經News,作者:問道、JXkin,Odaily星球日報經授權轉載。孫宇晨收購SteemitInc,還未施展他“去中心化社交網絡的新紀元”的運作,便招致Steem公鏈社區的.

1900/1/1 0:00:00
黑天鵝是生活的常態,寫在312比特幣暴跌之時_比特幣:區塊鏈

黑天鵝這個詞真正走入人們生活常態的時間大概是2007年開始,西姆·尼古拉斯·塔勒布把暢銷書《黑天鵝》這本書帶入了大眾視野,讓更多人知道了這個詞的存在.

1900/1/1 0:00:00
ads