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

讀懂 Bedrock:Optimism 落子布局 Rollup 生態的第一步_BED:DropsTab

Author:

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

原文標題:《BedrockExplainer》

撰文:Optimism?官方

編譯:Frank,ForesightNews

Bedrock是OPStack有史以來第一個正式版本的名稱,作為一組免費和開源的模塊化組件,它旨在為Optimism的發展提供動力。

改進總結

Bedrock在其前身的基礎上進行了改進,主要包含:

使用經過優化的批量交易壓縮以及將以太坊作為數據可用性層,從而降低交易費用;

通過更好地處理L1重組,縮短了將L1交易打包到rollups中的延遲;

通過代碼重用來啟用模塊化證明系統;

通過消除設計負債來提高節點性能。

更低的費用

Bedrock使用了經過優化的數據壓縮策略,以最大限度地降低數據成本。我們目前正在對這一變化的影響進行基準測試,但我們預計它將大幅降低費用。

Bedrock還消除了向L1提交數據時與EVM執行相關的所有Gas成本,與之前版本的協議相比,這將額外減少10%的費用。

更短的存款入賬時間

Bedrock在節點軟件中引入了對L1重組的支持,這大大減少了用戶等待存款入賬所需的時間。

該協議的早期版本最多可能需要10分鐘來確認存款入賬,而使用Bedrock后,我們預計存款會在3分鐘內確認入賬。

改進的模塊化證明

Bedrock從OPStack中抽象出了證明系統,以便rollup可以使用故障證明或有效性證明來證明在rollup上輸入后的正確執行,這種抽象也將允許使用Cannon來證明系統中的故障。

改進的節點性能

通過在單個rollup「區塊」中執行多筆交易,而不是之前版本中「每個區塊一筆交易」的模型,節點軟件性能因此得到了顯著提高。

這使得MerkleTrie更新的成本能在多筆交易中進行分攤,在當前的交易量下,這會使狀態數據的增長幅度每年減少大約15GB。

通過消除之前版本的協議中的技術負債,節點性能也得到進一步提高,這包括不再需要一個單獨的「數據傳輸層」節點來為L1編制索引,并更新節點軟件以有效地查詢來自L1的交易數據。

改進的以太坊等效性

Bedrock從一開始就被設計成盡可能與以太坊「一致」,先前版本協議中與以太坊的多項偏差已被消除,包括:

FTX批評UCC的資產控制追求:金色財經報道。FTX對無擔保債權人官方委員會(UCC)追求資產控制的做法提出了強烈批評。UCC 建議債務人將近 26 億美元的現金儲備分配給短期國債。FTX 在一份聲明中認為,此舉弊大于利,將危及加密貨幣行業的未來。FTX 還表示,這樣的決定可能會導致加密貨幣市場缺乏信任,從而產生長期的負面影響。該加密貨幣交易所敦促UCC重新評估其計劃,并考慮其他方案,以確保行業的穩定。[2023/8/11 16:19:52]

「每個區塊一筆交易」的模型;

自定義操作碼以獲取L1的區塊信息;

在JSON-RPCAPI中分離L1/L2費用字段;

ETH余額的自定義ERC20表示形式。

Bedrock還增加了對EIP-1559、區塊鏈重組和L1上存在的其他以太坊功能的支持。

設計原則

Bedrock被構建為模塊化和可升級的設計,同時可以復用以太坊的現有代碼,并盡可能達成?100%以太坊等效的目標。

模塊化

通過使用定義良好的接口和版本控制方案,Bedrock可以輕松地更換OP堆棧中的不同組件,并添加新功能。

這就允許其借助一個靈活的架構,適應以太坊生態系統的未來發展,例如:

rollup節點與執行客戶端分離;

模塊化防故障設計。

代碼復用

Bedrock盡可能地使用現有的以太坊架構和基礎設施,這種方法使OPStack能夠從以太坊主網使用的經過實戰測試的代碼庫中繼承安全性和林迪效應優勢。

您會在整個設計中找到這樣的示例,包括:

最少修改的執行客戶端;

EVM合約而不是預編譯的客戶端代碼。

以太坊等效性

Bedrock旨在最大程度地兼容現有的以太坊開發人員體驗,但由于L1和rollup之間的根本差異,也存在一些例外情況:費用模型的不同、更快的出塊時間以及包含L1存款交易的特殊交易類型。

這些例外情況包括:

旨在證明最小修改的以太坊執行客戶端的故障證明;

以太坊執行客戶端的代碼重用,以供L2網絡中的節點和排序器使用。

協議

Rollups建立在數據可用性的基礎上,在最常見的配置中,rollup協議從兩個主要信息來源派生出「規范的L2鏈」:

全國政協委員皮劍龍:加快網絡虛擬財產保護立法:金色財經報道,第十四屆全國政協委員、北京市金臺律師事務所主任皮劍龍擬向兩會提交《關于加快網絡虛擬財產保護專門立法的提案》。這一提案認為,當前對網絡虛擬財產保護進行專門立法的條件已基本成熟,建議全國人大盡快將《網絡虛擬財產保護法》列入立法規劃,啟動相關立法進程。皮劍龍認為,下一代互聯網會是價值網,而區塊鏈、智能合約、預言機、元宇宙、人工智能等等科技,是資產數字化的重要科技。許多國家以及歐盟均高度重視虛擬財產的發展,并且紛紛制定相關法規。如何發揮提升我國在下一代互聯網與新型數字經濟領域的國際競爭力,是擺在我們面前極其重要的問題。[2023/3/2 12:37:59]

交易數據由定序器發布到L1;

存款交易由賬戶和智能合約提交到L1上的橋接合約。

以下是該協議的基本組成部分:

通過直接與L1上的智能合約交互,將存款寫入「規范的L2鏈」;

提款是寫入「規范的L2鏈」,并隱式觸發與L1上智能合約和賬戶的交互;

Batches是與rollup上的batches相對應的數據寫入;

區塊推導是如何解釋L1上的數據讀取以理解「規范的L2鏈」;

證明系統定義了L1上發布的輸出根的最終性,以便它們可以被執行。

存款

存款是L1上的一筆交易,并將包含在rollup中。根據定義,存款被保證包含在「規范的L2鏈」中,作為防止審查或控制L2的一種手段。

從L1傳遞的任意消息

存款交易是作為存款的一部分進行的rollup交易。通過Bedrock,存款是完全通用的以太坊交易,例如以太坊上的賬戶或智能合約可以創建「存款」合約。

Bedrock定義了一個在L1上可用的存款合約:它是一個智能合約,L1帳戶和智能合約可以與之交互以寫入L2。L2上的存款交易是從該存款合約發出的交易中派生出來的,其中包括預期參數,例如from、to和data。

有關詳細信息,請參閱存款合約協議規范部分。

在L1上購買有擔保的L2Gas

Bedrock還明確了Gas燃燒機制和存款費用市場,存款交易在L2上花費的Gas是通過Gas燃燒在L1上購買的。

這種Gas具體是在費用市場上購買的,并且在單個L1區塊中提供給所有存款交易的Gas總量有一個硬性上限,該機制用于防止拒絕服務攻擊,這種攻擊可能發生在將交易從L1寫入L2時,因為這些交易在L2上耗費大量Gas,但在L1上卻很便宜。

加密KOL:12年前的今天,有人以0.25美元的單價購買了5萬枚BTC:金色財經報道,據加密KOL@pete_rizzo_發推稱,12年前的今天,有人以0.25美元的單價購買了5萬枚BTC。[2022/12/26 22:07:07]

提供給存款交易的Gas有時被稱為「有擔保的Gas」。GuaranteedGas的獨特之處在于它是通過在L1上燃燒Gas來支付的,因此是不可退還的。

且每單位有擔保的L2Gas所要求的必須燃燒的L1Gas總量,取決于EIP-1559式收費機制報告的L2Gas價格。此外,用戶根據計算費用機制更新所花費的L1Gas數量獲得動態Gas津貼。

如需更深入的解釋,請閱讀存款部分的協議規范。

提款

提款是在L2上發起并由在L1上執行的交易完成的跨層交易。值得注意的是,L2賬戶可以使用提款來調用L1合約,或將ETH從L2賬戶轉移到L1賬戶。

提款是通過在L2上調用MessagePasser預部署合約啟動的,該合約在其存儲中記錄了消息的重要屬性,然后通過調用OptimismPortal合約在L1上完成提款,以證明包含此提款消息。

這樣,提款和存款就不一樣了:提款交易必須使用L1上的智能合約來完成,而不是依賴于區塊派生出來的信息。

分兩步的提款過程

提款證明驗證錯誤是過去幾年許多跨鏈橋黑客攻擊事件的根本原因。Bedrock版本在先前版本的提款過程中引入了一個額外的步驟,旨在為這些類型的錯誤提供額外的防御設計。

在分兩步的提款過程中,每次提款必須在最終退出前7天提交與提款對應的Merkle證明,這種新的安全機制給了監控工具整整7天的時間來查找和檢測無效的提款證明。

在此期間如果發現提款證明無效,就可以在資金丟失之前部署智能合約修復,這大大降低了跨鏈橋妥協的風險。

有關詳細信息,請參閱提款協議規范部分。

批次交易

在Bedrock中,為L1和L2之間的消息傳遞定義了一種有線格式,這種有線格式的設計目的是將寫入L1的成本和軟件復雜性降到最低。

優化數據壓縮

為了優化數據壓縮,L2交易列表被組織到對象組中,每個channel的最大規模能夠在可配置參數中定義,最初將設置為9.5M,這些channel預計將使用壓縮功能進行壓縮并提交給L1。

batch并行提交

DAO Maker社區:團隊疑似通過操縱治理投票篡改承諾的賠償流程:10月17日消息,DAO Maker針對2021黑客攻擊事件的處理方案的變更在社區引起爭議。此前報道,DAO Maker在2021年黑客攻擊事件后,將部分損失金額以USDR形式空投給受影響用戶,并承諾USDR可在1年鎖定期后以110%的比例兌換DAO Token。然而,DAOMaker在今年10月12日發起投票,其中“停止USDR贖回”的方案在今日獲得最高票通過,提案給出的理由是“大多數想要賣出的人已經使用USDR-USDC流動性池賣出,且此舉將維護現有的DAO Token持有者的利益”。對此,部分社區成員認為,此舉是在打著關照用戶的幌子推卸責任,當前的投票者多數沒有經歷過當時的黑客事件,并懷疑“參與投票的6個大額Token持有地址為團隊所有”。[2022/10/17 17:29:03]

為了并行化來自向L1提交壓縮channel數據的定序器消息,channel被進一步分解為「channelframes」,這些「channelframes」是可以適合單個L1交易的壓縮channel數據塊。

假設「channelframes」是相互獨立的,并且順序是已知的,那么由定序器發送到L1的以太坊交易可以并行發送,從而最大限度地降低了定序器軟件的復雜性,并允許填充L1上所有可用的數據空間。

最小化以太坊Gas

Bedrock刪除了L1系統在稱為「batchertransactions」的交易中向L1提交channel數據所使用的所有執行Gas。之前發生在L1智能合約上的所有驗證邏輯都被移動到了區塊派生邏輯中。相反,「batchertransactions」被發送到以太坊上的單個EOA地址,稱為「batchinboxaddress」。

Batches仍需接受有效性檢查,batche中的單個交易也是如此,無效batches和有效batches中的無效單個交易被視為被丟棄并且與系統無關。

注意:以太坊將很快升級包含EIP-4844的新版本,它引入了一個單獨的數據寫入費用市場,并增加了以太坊協議愿意存儲的數據量上限,這一變化有望進一步降低與將數據發布到L1相關的成本。

如需更深入的解釋,請閱讀有線格式規范。

區塊派生

在Bedrock中,該協議的設計旨在保證L1上存款的時間與「規范L2鏈」的區塊派生有關。這樣做是通過定序器、存款和L1區塊屬性將數據寫入L1的純函數。

為了實現這一點,該協議定義了保證存款入賬、處理L1和L2時間戳以及處理channel中的排序窗口以確保正確排序的策略。

STEPN首席營銷官Shiti:反欺詐措施將減輕GST的銷售壓力,團隊提出STEPN行動計劃:6月15日消息,STEPN的首席營銷官Shiti表示,在過去的幾個月里,STEPN花費了大量時間在反作弊系統和防御DDOS攻擊上。該團隊認為,反欺詐措施將減輕GST的銷售壓力。STEPN將在未來每月進行主要更新,預計在這期間也會進行次要更新。

團隊還提出了STEPN行動計劃:優化realms間的能源共享;調整動態鑄造成本、增加鑄造成本,延長鑄造冷卻時間,返工神秘盲盒;運動鞋合成機制;即將發布的鑄造卷軸。[2022/6/15 4:29:47]

保證存款入賬

區塊派生協議的目標是這樣進行定義的:

每個「L2區塊間隔」過去后,必須有一個L2區塊,且L2區塊的時間戳與L1的時間戳保持同步。

在Bedrock中,引入了「sequencingepoch」的概念:它是由一系列L1區塊派生出來的L2區塊的范圍,每個epoch由一個「epochnumber」標識,該「epochnumber」等于排序窗口中第一個L1區塊的區塊序號。受一些限制,epoch的大小可以有所不同。

batch派生channel將與「epochnumber」相關聯的L1區塊的時間戳視為確定L2上交易順序的錨點。該協議保證一個epoch的第一個L2區塊永遠不會落后于所匹配epoch的L1區塊的時間戳。一個epoch的第一個區塊必須包含L1上的存款,以保證存款將被處理。

請注意,在Bedrock版本中,L2上的區塊間隔目標配置為2秒。

處理L1和L2時間戳

Bedrock試圖解決將L2上時間戳與存入交易中存在的L1上時間戳進行協調的問題。

它通過允許一個很短的時間窗口來進行排序,以便在epoch之間的L2交易上自由應用時間戳來實現這一點。

排序窗口是L1區塊的序列,從中可以導出epoch。一個排序窗口中,其第一個L1區塊的編號N包含epoch的「batchertransactions」。?

排序窗口包含區塊,其中取決于排序窗口的大小:一個固定的rollup級別配置參數必須至少為2,增加它會為定序器提供了更多關于存款的L2交易排序機會,降低它為定序器提交「batchertransactions」引入的更嚴格時間窗口。這是在創造MEV機會和增加軟件復雜性之間的權衡。

稱為「最大定序器漂移」的協議常量控制一個區塊在其?epoch?內可以具有的最大時間戳,有了這種漂移,定序器就可以在連接到L1出現臨時問題時保持活躍。

區塊派生管道

「規范的L2鏈」可以從頭開始處理,方法是從L2創世狀態開始,將L2鏈起始設置為第一個epoch,然后處理所有排序窗口,以便根據以下簡化的順序確定定序器batches和存款的正確順序管道:

故障證明

在定序器處理一個或多個L2區塊后,從這些區塊中執行交易計算得出的輸出將需要用L1寫入,以實現L2到L1消息傳遞的無信任執行,例如提款等。

在Bedrock中,輸出以樹形結構的形式進行哈希處理,從而最大限度地降低了證明輸出捕獲的任何數據片段的成本。提議者定期向L1提交作為整個「規范L2鏈」的Merkle根的輸出根。

OPStack的未來升級應該包括一個故障證明變體的規范,其中包含綁定,以激勵提議者提出正確的輸出根。

有關完整詳細信息,請閱讀?L2輸出根提案部分的協議規范。

執行

在Bedrock中,OPStack通過鏡像以太坊執行層和共識層之間的分離,在很大程度上不得不依賴于以太坊指定的技術關注點分離。

所以Bedrock以同樣的方式引入了執行客戶端和rollup節點的分離。

執行客戶端

執行客戶端是定序器和其他類型的節點操作員運行以確定「規范L2鏈」狀態的系統。它還執行其他功能,例如處理入站交易和點對點通信,以及處理系統狀態以處理針對它的查詢。

借助Bedrock,OPStack旨在重用以太坊自己的執行客戶端規范及其許多執行操作。在此版本中,Bedrock展示了對以太坊客戶端go-ethereum的極其有限的修改,其差異小于2000行代碼。

存在差異的根本原因有兩個:處理存款交易和收取交易費用。

處理存款交易

為了在rollup中表示已存入的交易,引入了一種額外的交易類型。執行客戶端實現這個新的交易類型是根據EIP-2718類型的交易標準。

收取交易費用

Rollups從根本上說還有兩種與交易相關的費用:

一個是定序器費用。使用與以太坊相同的Gas表和相同的EIP-1559算法計算操作定序器的成本,這些費用用于操作排序器的協議,并根據網絡擁堵情況隨時波動。

另一個數據可用性費用。數據可用性成本與將批次處理交易寫入L1相關,這些費用旨在支付定序器向L1提交批次交易所需支付的費用。

在Bedrock中,費用的數據可用性部分是根據稱為GasPriceOracle的rollup系統智能合約中的信息確定的,該智能合約在區塊派生過程中,是根據從每個epoch開始時插入的L1區塊屬性中檢索到的Gas價格信息進行更新。

Bedrock指定在使用JSON-RPC時將這兩種費用加到一個字段中。

rollup節點

與以太坊不同,Bedrock沒有PoS共識。相反,「規范的L2鏈」的共識是由區塊派生定義的。OPStack的執行客戶端與一個新組件通信,該組件實現了稱為rollup節點的區塊派生,該節點使用與以太坊完全相同的引擎API與執行客戶端通信。

rollup節點是一個無狀態組件,負責通過讀取L1上的數據和存款來推導系統的狀態。在Bedrock中,rollup節點可用于對來自用戶或其他匯總節點的傳入交易進行排序,或者通過單獨依賴L1來驗證在L1上發布的已確認交易。

rollup節點的多種用途概述如下:

驗證「規范的L2鏈」

運行rollup節點的最簡單模式是只遵循「規范的L2鏈」。在這種模式下,rollup節點沒有對等節點,嚴格用于從L1讀取數據并根據區塊派生協議規則對數據進行解釋。

這種節點的一個目的是根據協議定義驗證由其他節點共享或發布在L1上的任何輸出根是否正確。此外,打算將輸出根提交給L1的提議者自己可以使用optimism_outputAtBlock生成他們需要的輸出根,并返回對應于L2輸出根的32字節哈希值。

為此,節點應該只需要跟隨「最終確定」的區塊頭。術語「finalized」指的是以太坊PoS共識,而「最終確定」的L2區塊頭是僅從「最終確定」的L1區塊派生的「規范L2鏈」的區塊頭。

參與L2網絡

使用rollup節點的最常見方法是參與其他rollup節點的網絡、跟蹤L2的進程和狀態。在這種模式下,rollup節點同時讀取數據和它從L1觀察到的存款,將其解釋為區塊,并接受來自其他rollup節點網絡中的用戶和對等方的入站交易。

參與網絡的節點可以使用它們正在同步的L2的安全和不安全區塊頭。

安全的L2區塊頭表示可以構建的rollup,其中每個區塊都可以完全從參考L1鏈中導出,在L1必須「最終確定」之前;

不安全的L2區塊頭包括尚未從L1派生的不安全區塊。這些區塊要么來自將rollup節點作為定序器操作,要么來自不安全的同步與定序器。這也稱為「最新」區塊頭。在出現分歧的情況下,總是選擇安全的L2區塊頭而不是不安全的L2區塊頭。當出現分歧時,該鏈的不安全部分將重組;

在大多數情況下,對于終端用戶應用程序,L2網絡中的rollup節點將引用不安全的L2區塊頭。

交易排序

使用rollup節點的第三種方法是對交易進行排序。在這種模式下,rollup節點將在不安全的L2區塊頭之上創建新區塊。目前,每個OPStack網絡只有一個定序器。

定序器還負責將批次交易發布到L1,以便網絡中的其他節點從中同步。

Batcher

定序器的作用是生產批次交易,為此,排序器可以運行rollup節點并具有單獨的進程,這些進程通過從它們運行的??受信任的rollup節點讀取來執行批處理。

這保證了OPStack的一個附加組件,稱為批次交易處理程序,它從rollup節點讀取交易數據并將其解釋為要寫入L1的批處理交易,batcher組件負責讀取由定序器運行的rollup節點的不安全L2區塊頭,創建batcher交易,并將它們寫入L1。

標準橋接合約

Bedrock還包括一對用于最常見類型存款的橋接合約,稱為標準橋接合約。這些合約封裝了存款和提款合約,為ETH和ERC-20代幣的存款和提款提供簡單的接口。

這些橋接合約的設計是在跨鏈橋的一側為本地代幣,另一側包含一個可以管理鑄造和銷毀的封裝代幣,橋接原生代幣涉及將原生代幣鎖定在合約中,然后在跨鏈橋的另一側鑄造等量的封裝代幣。

有關詳細信息,請參閱標準跨鏈橋協議規范部分。

Cannon

雖然在Cannon中實現了防故障構建和驗證,但故障證明游戲規范和將輸出根挑戰者集成到rollup節點中是后續規范里程碑的一部分。

延伸閱讀

協議規范

協議規范定義了OPStack的技術細節,它是協議內部運作的最新事實來源。

Bedrock差異

要深入了解Bedrock與先前版本之間的差異,請參閱「Bedrock有何不同」。

Tags:BEDDROEDRROLBEDOGEDropsTabEDRAROLC

芝麻開門交易所下載
GameFi 里的 4399,?Magic 會是下一個任天堂嗎?_REA:TREASURE

作者:Fiona,IOSGVentures TL;DR? 我們正處于從以基礎設施為中心轉向以用戶為中心的過程中,而GameFi扮演著重要的角色,既能吸引主流用戶同時又能增強用戶粘性.

1900/1/1 0:00:00
Genesis 是 FTX 最大的無擔保債權人_GEN:Pepe Next Generation

據周四修改后的文件,FTX及其附屬子公司欠GenesisGlobalCapital2.263億美元.

1900/1/1 0:00:00
Polygon“奧德賽”活動開啟,該如何參與?_POL:DragonBnB.co

作者:TokenInsight以太坊擴容方案Polygon宣布推出PolygonDeGens活動,旨在展示Polygon上的DeFi機會,并提高PolygonDeFi社區的認識.

1900/1/1 0:00:00
天橋資本創始人將投資 FTX US 前總裁創立的加密公司_SON:AGORAM幣

天橋資本創始人AnthonyScaramucci表示,將用自己的錢投資FTXUS前總裁BrettHarrison成立的加密貨幣公司.

1900/1/1 0:00:00
從三大維度解析頭部公鏈如何實現差異化運營_APT:Aptos

作者: Zolo,深潮TechFlow;linda鄭鄭,SuiWorldCo-Founder最近流行幾張圖,展示了各條公鏈的開發者數,日活數據等等.

1900/1/1 0:00:00
加密風投機構 Escape Velocity 已為其首支加密基金募資 2500 萬美元,A16z 等參投_ENT:RESQ幣

據TheBlock報道,加密風投機構EscapeVelocity已為其首支加密基金募資2500萬美元,未來幾周正式關閉之前募資總額可能會達到3000萬美元的上限.

1900/1/1 0:00:00
ads