比特幣交易所 比特幣交易所
Ctrl+D 比特幣交易所
ads

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

Author:

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

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

「每個區塊一筆交易」的模型;自定義操作碼以獲取L1的區塊信息;在JSON-RPCAPI中分離L1/L2費用字段;ETH余額的自定義ERC20表示形式。Bedrock還增加了對EIP-1559、區塊鏈重組和L1上存在的其他以太坊功能的支持。

Ribbon Finance旗下Aevo推出永續期貨:5月18日消息,鏈上結構化產品 Ribbon Finance 旗下衍生品交易平臺 Aevo 宣布推出永續期貨,此前,Aevo 已推出期權產品。[2023/5/18 15:11:53]

設計原則

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

模塊化

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

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

rollup節點與執行客戶端分離;模塊化防故障設計。代碼復用

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

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

最少修改的執行客戶端;EVM合約而不是預編譯的客戶端代碼。以太坊等效性

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

這些例外情況包括:

旨在證明最小修改的以太坊執行客戶端的故障證明;以太坊執行客戶端的代碼重用,以供L2網絡中的節點和排序器使用。協議

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

交易數據由定序器發布到L1;存款交易由賬戶和智能合約提交到L1上的橋接合約。以下是該協議的基本組成部分:

通過直接與L1上的智能合約交互,將存款寫入「規范的L2鏈」;提款是寫入「規范的L2鏈」,并隱式觸發與L1上智能合約和賬戶的交互;Batches是與rollup上的batches相對應的數據寫入;區塊推導是如何解釋L1上的數據讀取以理解「規范的L2鏈」;證明系統定義了L1上發布的輸出根的最終性,以便它們可以被執行。存款

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

以太坊編程語言Solidity發布最新版本編譯器Solidity 0.8.18,支持巴黎硬分叉:金色財經報道,以太坊編程語言Solidity發布最新版本的Solidity編譯器Solidity0.8.18,新版本的功能包括:禁用CBOR元數據、支持巴黎硬分叉、棄用selfdestruct、從Yul生成EVM字節碼。團隊建議所有Solidity開發人員升級到版本0.8.18以利用這些改進和優化。[2023/2/2 11:43:19]

從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上卻很便宜。

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

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

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

提款

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

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

紐約金融服務部擬向紐約加密公司收費以進行監管:金色財經報道,紐約金融服務部(NYDFS)周四公布了一項擬議法規,允許NYDFS向紐約加密公司收費來“支付運營費用”。擬議的法規是在紐約州參議院首次授權NYDFS向其監管的加密貨幣公司收費八個月后出臺的,使其對加密的監管與監管傳統銀行和金融服務公司的方式保持一致。只有擁有BitLicense(NYDFS授予的允許公司在紐約開展業務的特殊營業執照)的加密貨幣公司才會接受收費評估,目前只有22家公司持有BitLicense,而NYDFS今年只發放了3張BitLicense許可證。

NYDFS主管Adrienne Harris在新聞稿中表示,額外的資金將使該機構能夠加強其加密貨幣團隊,這反過來將“幫助該部門繼續保護消費者并確保該行業的安全和穩健”。新法規已開啟了為期10天的提案前評論期,隨后是法規草案在國家登記冊上發布后的60天評論期。評論期結束后,NYDFS將發布修訂提案或采用當前形式的法規的通知。[2022/12/2 21:16:36]

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

分兩步的提款過程

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

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

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

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

批次交易

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

優化數據壓縮

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

batch并行提交

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

Rubic:管理員地址私鑰疑被泄露,攻擊者已出售約3400萬RBC/BRBC:11月2日消息,鏈兌換協議Rubic發推稱,管理員的一個錢包地址被盜用了,該地址管理RBC/BRBC跨鏈橋和質押獎勵,團隊懷疑是惡意軟件盜取了私鑰。攻擊者在Uniswap和PancakeSwap上售出了大約3400萬RBC/BRBC,用戶的質押資金是安全的,智能合約沒有被利用。團隊正在處理這種情況,會及時通知接下來的步驟,Staking獎勵將在幾天后恢復。[2022/11/2 12:10:08]

假設「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中的排序窗口以確保正確排序的策略。

保證存款入賬?

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

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

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

說唱歌手HotDog熱狗推出新歌《NFT》:金色財經消息,據QQ音樂,說唱歌手HotDog熱狗推出名為《NFT》的歌曲,QQ音樂顯示發行時間為2022年6月2日。[2022/6/2 3:58:35]

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有何不同」。

責編:Lynn

Tags:ROLLROLROCEDRRollerSwapROCKIHedron

比特幣交易
Nostr的野心,不止替代Twitter_NFT

今天這篇文章主要想試圖探討幾個問題:1.Nostr協議的緣起和起承轉合,比如說它是出于什么想法和思路創建的.

1900/1/1 0:00:00
創新還是攻擊?梳理比特幣鏈上“NFT巨塊風波”_COIN

2023年2月1日,比特幣挖出近4M的史上最大區塊,里面包含一個近4M的史上最大交易,并且交易費為0!這筆巨大交易由獨立開發者@udiWertheimer的比特幣鏈上NFT項目“TaprootW.

1900/1/1 0:00:00
如何在Crypto市場構建護城河?_OIN

WarrenBuffett拒絕投資沒有護城河的公司。了解護城河概念可以幫助您確定更好的加密投資。以下是您應該建立的7條護城河:護城河是難以復制的競爭優勢.

1900/1/1 0:00:00
你的 Web3 產品真的需要代幣嗎?_WEB3

自從代幣在2017年ICO時代開始流行以來,我們經歷了多種敘事和用例的循環,從使用代幣籌款,到授權社區治理,一直到發布產品的新方式.

1900/1/1 0:00:00
Delphi Digital:我們為什么看好 Sei Network_OLA

1月4日,加密貨幣交易所MEXC宣布啟動2000萬美元專項基金,用于支持SeiNetwork重點項目發展.

1900/1/1 0:00:00
MarsBit日報 | 比特幣挖礦難度續創歷史新高;USDT市場占比達2021年11月以來最高水平_元宇宙

MarsBitCryptoDaily2023年1月29日 一、?今日要聞 今年1月迄今加密貨幣基金普漲,當前ValkyrieBitcoinMinersETF表現最佳據外媒報道.

1900/1/1 0:00:00
ads