加密貨幣交易所 加密貨幣交易所
Ctrl+D 加密貨幣交易所
ads

詳解以太坊2.0如何與1.0合并_ETH:以太坊

Author:

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

(圖片來自:tuchong.com)以太坊1.0和以太坊2.0客戶端的關系

自從Vitalik在2019年12月提出一個早期eth1<->eth2合并替代方案之后,研究人員一直在進行積極討論,以從軟件的角度來考慮這種合并的可能形式,而對于原型設計的期望,也是愈發變得更強。我們的愿景是創建一個混合體,其中核心共識工作是由以太坊2.0客戶端管理,而狀態/區塊則由一個以太坊1.0引擎管理,而它們一起構成了eth1+eth2組合客戶端。本文旨在更明確地區分eth2客戶端和附屬eth1引擎之間的職責,以便為會話、規范編寫及原型提供更好的基礎。注意,文章并不會定義協議的具體細節,并且文中包含的任何示例,都只是用于幫助描述及后續討論。而要理解本文的內容,前提條件是需要你基本熟悉以太坊2.0以及無狀態以太坊的概念。分工明確

eth1+eth2的合并目的,是在升級的以太坊2.0共識環境中利用現有以太坊1.0的狀態、生態系統以及軟件。概括地說,我們今天所認為的eth2客戶端會處理核心PoS以及分片共識。本質上,eth2協議及eth2客戶端被設計成非常擅于在一堆“東西”上產生及達成共識,而這些東西,就是很多充滿數據和狀態的分片鏈。與當今eth1的PoW共識層相比,eth2的“共識層”要先進的多,同時也復雜的多。今天,eth1客戶端具有相對簡單且較薄的共識層,它只有一條鏈,并且PoW可處理協議外硬件中的大部分復雜性。eth1客戶端的大多數復雜性及優化,都位于用戶層。當eth1作為一個分片被納入eth2時,這種關注點分離就可實現很好的配對,eth2客戶端可以處理PoS和分片共識的復雜性,而附屬eth1客戶端可以成為eth1引擎,它可以處理狀態、交易、虛擬機以及更接近用戶層事物的復雜性。最小的改變,實現本地通信

PeckShield:Justin Sun地址從Liquity提取并解除質押超250萬枚LQTY后存入Binance:2月28日消息,PeckShield監測顯示,鏈上標記為 Justin Sun 的地址從 Liquity 提取和解除質押超 250 萬枚 LQTY ( 約 590 萬美元),并轉移至 Binance。[2023/3/1 12:35:08]

如何將eth1和eth2客戶端軟件組合在一起,有很多可能的途徑,但在本文當中,我們會重點介紹一個最具微創性和和模塊化的方法——一種eth2客戶端與簡化eth1引擎之間的本地通信協議。考慮到eth1和eth2客戶端實現的多樣性,這種方法可以防止客戶端軟件在任一側鎖定,允許客戶端團隊保持獨立,并專注于他們自己的研發工作,使軟件項目在很大程度上保持穩定,以便進行快速原型制作。那它會是什么樣子的呢?大致上,一個eth1+eth2組合客戶端會是下面這個樣子的:

其中eth2引擎和eth1引擎一起運行,通過eth2客戶端驅動的RPC進行本地通信。兩者都會維護自己的p2p接口,連接到對等方并處理與每個特定域相關的網絡協議。以太坊2.0客戶端

Celo與ConsenSys達成合作,將集成Infura基礎設施:11月21日消息,Celo與以太坊基礎設施開發公司ConsenSys達成合作,將集成ConsenSys旗下區塊鏈開發平臺Infura的基礎設施。Celo開發者將能夠使用Infura進行構建,這將有助于使其區塊鏈更具可擴展性。開發者還將能夠部署使用Truffle構建、基于以太坊的DApp。

此外,本次合作還將使得ConsenSys旗下瀏覽器錢包MetaMask提高對Celo的兼容性。(CoinDesk)[2022/11/21 7:52:55]

信標鏈和信標狀態;分片鏈;Mempool操作、存款、退出出口等)P2P接口;RPC到eth1引擎;以太坊1.0引擎

EVM虛擬機;eth1狀態;交易存儲池Mempool;P2P接口;來自eth2客戶端的RPC;共識

從核心共識的角度來看,eth2客戶端負責并推動信標鏈、數據分片鏈以及eth1分片鏈的構建。eth2客戶端通過RPC直接提供有關eth1引擎關于eth1分片鏈和核心共識的任何知識。具體來說,附加的eth1引擎必須能夠訪問eth2客戶端,因為它不能維護自己的共識。在今天以太坊的PoW中,eth1客戶端檢查工作量證明,形成一個樹狀結構,并運行分叉選擇規則來查找鏈的頂端。在eth2中,這些機制要大不相同,這需要對eth2的核心共識有深入的了解。eth2客戶端提供有關eth1分片鏈頭部的最新信息,以便eth1引擎可以維護eth1狀態的準確視圖。由于eth1引擎完全依賴eth2客戶端推動共識,因此我們提議eth2客戶端與eth1引擎之間的通信,都是eth2客戶端調用的eth1引擎上的所有方法。這將強制執行一個leader/follower關系,以降低系統推理的復雜性,并限制eth1引擎所需的業務邏輯。從eth2客戶端和核心共識的角度來看,eth1分片鏈的處理,幾乎與所有其他分片鏈完全相同。主要區別在于,可以針對eth1引擎執行分片區塊內容,因此eth1分片區塊數據的格式必須與eth1相關,并且必須針對此成功執行進行額外的驗證。狀態

美聯儲鮑曼:如果通脹沒有降溫,仍有可能“大幅”加息:金色財經報道,美聯儲理事鮑曼(Michelle Bowman)周三表示,如果高通脹率沒有開始減弱,她將繼續支持積極的利率上升。她說:“通貨膨脹率太高了,我堅信,將通貨膨脹率拉回到我們的目標,是實現價格穩定和在可持續基礎上實現最大就業目標的一個必要條件。”

鮑曼表示,通貨膨脹的情況將決定美聯儲的下一步計劃。如果沒有看到通脹率下降的跡象,我的觀點仍然是,聯邦基金利率目標范圍內的可觀增長應該仍在考慮之列。但她也表示,如果通貨膨脹開始降溫,放慢加息步伐是合適的。

此外,鮑曼稱,為了以持續和持久的方式使通貨膨脹率下降,聯邦基金利率將需要升至一個限制性水平,并在那里保持一段時間。(路透社)[2022/10/13 14:26:08]

eth2有一種與核心共識相關的狀態,這就是所謂的“信標狀態”。信標狀態數據很小,它包含了理解核心共識及如何處理分片鏈所需的所有信息。事實上,要處理分片鏈中與共識相關的部分,客戶端必須能夠訪問信標狀態。eth2的狀態不會一直和用戶層狀態交互,其交互最多的是分片鏈數據的可用性。實際的用戶層數據根位于該分片鏈數據中,對于eth1分片鏈,則為當前以太坊用戶狀態根。下面討論了和eth2客戶端相關的eth1狀態的不同情況:1、沒有eth1引擎的eth2客戶端核心eth2協議可以在沒有附加eth1引擎的情況下運行。單獨的eth2客戶端可以遵循信標鏈和分片鏈。而沒有eth1引擎,客戶端將無法執行無狀態eth1分片區塊,因此無法完全驗證它們或從中獲取任何有用的用戶信息。不過,根據對eth2核心共識和驗證者的假設,eth1分片鏈的頭部仍然可以安全地找到。2、帶無狀態eth1引擎的eth2客戶端要運行一個驗證者節點,必須使用附加的eth1引擎運行eth2客戶端。這可以通過無狀態的方式完成,因此eth1分片區塊具有可用于執行的驗證數據。信標委員會可以通過對eth1引擎進行無狀態調用,來檢查分片區塊數據的可用性及關于eth1的數據有效性。除了驗證者外,很多用戶/應用程序節點也可能使用無狀態或半狀態的eth1引擎運行。使用瘦eth2客戶端,來跟隨eth1分片鏈的頭部,并以無狀態或半無狀態的方式與其交互。3、帶有狀態eth1引擎的eth2客戶端要運行可產生eth1分片區塊的驗證者,必須使用附加的eth1引擎和完整的eth1狀態運行eth2協議。然后,可以使用本地狀態和交易存儲池按需形成新的有效區塊。除驗證者外,很多用戶/應用程序節點也可能使用完全有狀態的eth1引擎運行,例如區塊瀏覽器、存檔節點、狀態提供者等。網絡

巴黎圣日耳曼推出友誼賽NFT門票,每張價值超20萬美元:金色財經報道,法甲足球俱樂部巴黎圣日耳曼本月將與日本當地球隊進行友誼賽,該俱樂部正在出售每張價值3000萬日元(約218,817美元)的NFT門票。據悉,NFT門票買家將被允許進入體育場的貴賓室和貴賓派對,還可以與PSG球員合影。球隊的明星足球運動員內馬爾、姆巴佩和梅西將參加日本之旅。(Forkast)[2022/7/11 2:04:48]

為簡單起見,eth2和eth1最初會維護它們各自獨立的網絡堆棧和協議。為了響應責任轉移,開發者已不贊成使用某些現有的eth1協議,取而代之的是eth2協議。在初始原型設計階段之后,或者在更進一步的階段,可能需要將eth1協議遷移到libp2p以統一網絡堆棧,但這不是必須的。eth2客戶端和eth1引擎可以訪問相同的discv5DHT,但是可獨立地找到具有適當功能的對等節點并獨立地維護連接。ENR

eth1+eth2組合客戶端會使用一個ENR,因為節點位于具有多個功能的邏輯網絡標識之后。eth1功能由ENR中的現有ethkey表示。eth2功能在ENR中用eth2key表示。每種協議的存在,都意味著節點能夠且愿意識別底層網絡協議的類別。Wire協議

1、eth2協議1、eth2請求/響應;2、核心共識gossip;2、eth1協議1、eth1wire協議的子集2、NOT;3、為什么eth2客戶端會處理eth1區塊gossip?eth2專門用于處理分片區塊的生產、gossip以及驗證。我們的目標是讓eth1分片成為標準分片,并盡可能與其余分片保持一致。關于核心共識,與其他分片相比,eth1區塊的主要區別在于針對eth1引擎執行/驗證區塊內容的能力,當驗證者正在將eth1分片區塊叉聯到信標鏈時,eth2客戶端將再次調用eth1引擎來執行和驗證該區塊。當有狀態的eth1+eth2組合節點收到新的eth1分片區塊時,eth2客戶端將再次調用eth1引擎,以驗證該區塊并更新本地狀態存儲。交易gossip和存儲池mempool

俄羅斯銀行Sber將于下個月進行其第一筆數字資產交易:金色財經報道,Watcher.Guru發推稱,俄羅斯最大的銀行Sber將于下個月使用其專有平臺進行其第一筆數字資產交易。[2022/6/16 4:30:54]

eth1引擎幾乎會以當前以太坊相同的方式,維護用戶交易gossip以及eth1交易儲存池。同樣的網絡協議和本地機制,可以用于gossip及存儲池的維護,為區塊的生產做好準備。主要的區別在于如何確定已用交易的知識,以及如何將存儲池用于區塊生產,但這些可以說是位于存儲池外部的一個層中。eth1分片區塊是從附屬eth2客戶端提供給eth1引擎的。包含在這些區塊中的交易,應該以類似于當前以太坊主網PoW區塊的方式從存儲池中清除。eth1分片區塊是根據附屬eth2客戶端,通過存儲池mempool的內容生成的。此RPC方法和基礎功能類似于getWork,但將返回完整的區塊內容,而不僅僅是一個哈希值。區塊生產

在eth2協議中,所有區塊必須由PoS驗證者根據核心共識進行生產及簽名。為此,eth2客戶端最終要負責所有區塊的生產。對于信標區塊和非eth1分片區塊,eth2客戶端具有生成有效區塊所需的一切。對于eth1分片區塊,eth2客戶端立即/隨時訪問eth1狀態、交易和其它底層eth1結構,以生成有效區塊。相反,當指定驗證者生成eth1區塊時,eth2客戶端從eth1引擎請求一個可行的eth1區塊數據。然后,eth2客戶端將此eth1區塊數據打包到完整的分片區塊中,并將該區塊廣播至網絡。eth1引擎之所以能夠生成有效/可行的eth1區塊數據,是因為它采用了今天以太坊主網所使用的相同方式來管理eth1交易存儲池,并且它通過eth2客戶端的更新來維護eth1頭狀態的最新信息。下一步該怎么走?

如果這一總體設計被大家認同,那接下來的步驟包括:確保有關eth2客戶端驅動eth1引擎的假設與現有eth1軟件一致,并且不會給現有eth1軟件帶來意外的負擔;更明確地定義用于驅動eth1引擎的通信協議,例如new_head(block)、validate_block_transition(block)、get_proposal(parent_root)等;定義網絡組件,例如需要eth1協議的哪一個子集,如何具體使用ENR;擴展以太坊2.0階段1規范原型!本文經作者DannyRyan授權翻譯。

Tags:ETHETH2以太坊SIP游戲名《TogetherBnB》rETH2價格以太坊硬幣可以賣錢么Space SIP

歐易交易所app下載
美國政府起訴“云挖礦”Ultra Mining:有中國礦場,購買螞蟻S17+_PPL:ripple幣最新消息

美國政府機構機構得克薩斯州證券委員會和阿拉巴馬州證券委員會周三對云挖礦機構UltraBTCMining及其代理機構LauraBranch提出了訴訟.

1900/1/1 0:00:00
BTC再次站上7000美金,近期行情反復波動的癥結在哪里?_BTC:btcz幣挖礦教程

昨天BTC受小時/4小時級別MA60均線壓制,但晚間卻反彈上漲,再次站上了7000美金,背后是受到原油行情的影響。如果我們只看4小時級別的行情,BTC呈現出很明顯的畫門行情走勢.

1900/1/1 0:00:00
Libra發行會改變穩定幣的格局?_LIBRA:數字貨幣

近兩日,各大媒體網站被DCEP和Libra刷屏,歸根結底還是由于數字貨幣這個概念受到幣圈投資者廣大關注,若是同為數字貨幣的DCEP和Libra被社會廣泛認可.

1900/1/1 0:00:00
穩定幣的啟發:如何構建新型借貸緩沖模型_穩定幣:ethylpenta

編者按:本文來自頭等倉區塊鏈研究院,Odaily星球日報經授權轉載。去中心化穩定幣似乎存在矛盾:雖然其目標是打造非監管資產,但它們也只能通過添加不相關資產來實現完全穩定.

1900/1/1 0:00:00
Gate.io研究院:2020年數字貨幣衍生品的發展現狀調查_數字貨幣:gate.io官網下載最新版

自2009年比特幣誕生,數字貨幣發展約為11年,而數字貨幣衍生品市場則是在2014年BitMEX數字貨幣衍生品交易所正式開啟,在2018年后,多家數字貨幣交易所推出期貨交易業務.

1900/1/1 0:00:00
最接地氣的零知識證明解釋_BTC:數字資產管理系統

編者按:本文來自萬向區塊鏈,Odaily星球日報經授權轉載。小A、小B、小C三個小朋友是學霸,非常喜歡玩數獨游戲,而且經常湊一起解決難題,以此證明自己更聰明.

1900/1/1 0:00:00
ads