加密貨幣交易所 加密貨幣交易所
Ctrl+D 加密貨幣交易所
ads
首頁 > ETH > Info

關于 Optimistic Rollup,你需要知道的一切(上)_以太坊:區塊鏈上班都是干什么的

Author:

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

以太坊生態的最大挑戰之一是如何在資源有限的前提下實現低延遲和高吞吐量。

系統的去中心化程度取決于網絡中最弱的節點驗證系統規則的能力。可以在低資源硬件上運行的高性能協議被稱為“可伸縮的”。

在本文中,我們將深入探究現代“Layer2方案”的原則,這些方案的安全模型,及其在解決以太坊可擴展性問題上采取的策略。

本文的預設讀者是那些對密碼學技術感興趣的人。如果你想要深入了解以太坊前沿可擴展性技術,以及如何設計并構建這類系統,千萬不要錯過這篇文章。

在本文中,重要的關鍵詞和概念都已加粗,因為這些都是你在了解密碼學貨幣技術時經常遇到的術語。本文涉及的概念比較復雜。如果你在閱讀中遇到困惑,請不要放棄,守得云開見月明。

區塊鏈資源要求

在比特幣和以太坊等去中心化網絡中,運行節點的資源要求主要有三種:

帶寬:下載并廣播區塊鏈相關數據的成本。

計算:在腳本或智能合約中運行計算的成本。

存儲:出于索引目的存儲事務數據的成本,以及為了繼續處理新的事務塊而存儲“狀態”的成本。

影響性能的因素有:

吞吐量:系統每秒可處理事務的數量

延遲:處理一筆事務所需的時間

數據:一巨鯨解押7900萬枚MATIC并轉移到幣安拋售致價格下降:11月28日消息,據Lookonchain監測,一巨鯨地址在11月15日解除質押了7900萬枚MATIC(價值約6500萬美元),然后陸續轉移至幣安,每次拋售都導致MATIC價格下跌。該地址目前仍持有3600萬枚MATIC(約合2980萬美元),可能會再次拋售。[2022/11/28 21:06:15]

比特幣和以太坊等新興密碼學貨幣網絡的理想特性是去中心化。那么問題來了,網絡是如何實現去中心化的呢?

低信任:有了這個特性,任何人都能自主驗證比特幣的總供應量永遠不會超過2100萬個,及其持有的比特幣不是偽造的。運行節點軟件的人可以獨立計算最新狀態,并驗證出塊流程是否遵循所有規則。

低成本:如果節點軟件的運行成本很高,人們就會選擇依靠可信第三方來驗證狀態。成本高意味著信任要求也高,這是我們極力想要避免的。

另一個理想特性是可擴展性:吞吐量能夠隨運行節點的成本增加呈超線性增長。這個定義很棒,但是并未指明與“信任”慣性。因此,我們另外定義了“去中心化可擴展性”:在幾乎不會提高系統信任假設的情況下實現可擴展性。

以太坊的運行時環境是EVM。在EVM中,事務在執行不同操作時需要承擔的成本不同。事務的計算單位叫做“gas”。在以太坊系統中,每個區塊的gas上限被設為1250萬gas。平均每12.5秒可以挖出一個區塊。由此可得,以太坊的延遲是12.5秒,吞吐量是每秒100萬gas。

FTX將啟動對其全球資產的戰略審查:11月19日消息,FTX宣布,作為破產法第11章流程的一部分,將啟動對其全球資產的戰略審查,以最大化可回收價值。法院文件顯示,由于債務人的公司記錄存在缺陷,FTX及其旗下公司一直無法收集完整的外國供應商名單或預先索賠金額。(財聯社)[2022/11/19 22:06:56]

你可能會問一個問題:每秒100萬gas能做什么?

每秒可完成大約47筆“簡單轉賬”事務。所謂“簡單轉賬”事務,就是指“A向B轉了一筆ETH”這樣最基礎的事務。每筆事務需要2.1萬gas。

每秒可完成大約16筆ERC20代幣轉賬。這類事務相比ETH轉賬事務需要執行更多存儲操作,因此每筆事務需要約6萬gas。

每秒可完成大約10筆Uniswap資產交換操作。代幣對事務的平均成本約為10.2萬gas。

……選擇你感興趣的事務,用100萬gas除以其gas消耗量。

請注意,隨著事務的執行復雜度提高,系統的吞吐量急劇下降。還有很大的提升空間!

方案1:使用中間方

我們可以使用大家都信任的第三方來達成所有事務。這樣一來,我們就可以得到很高的吞吐量,并將延遲降至亞秒級。簡直太棒了!這樣也不會改變任何系統參數,但是我們需要參與一個由第三方單方面設置的信任模型。第三方可能會對我們進行審查,甚至奪走我們的資產,這就不妙了。

Web3公司Everyrealm推出一款針對計成人的虛擬房地產游戲:金色財經報道,元宇宙內容開發商Everyrealm正在推出一款針對成年人的“家居設計”和虛擬房地產游戲。根據公告,經過三年多的開發,Everyrealm的新免費游戲--名為Hometopia,它允許玩家“與朋友一起”建造虛擬住宅和社區。Everyrealm還說,玩家還將被允許擁有他們在游戲中創造的東西。

Hometopia的開發者Alex Ahlund曾參與過《Design This Home》和《Design This Castle》等手機游戲,他希望該游戲能取得類似于最暢銷的PC游戲《模擬人生》的成功。(The Block)[2022/10/15 14:28:20]

方案2:擴大區塊容量并提高出塊頻率

我們可以通過減少出塊時間來降低時延,我們還可以通過提高區塊gas上限來提高吞吐量。這一改變可能會導致節點運營成本提高,從而阻礙人們運行節點。

方案1會提高對信任的需求,方案2會增加成本。因此,二者都不是理想的可擴展性方案。

重新認識OptimisticRollup

接下來會涉及一些關于哈希函數和默克爾樹的知識。

了解了這么多之后,我們來模擬一段蘇格拉底式對話,看看能否找到一個既能提高以太坊的實際吞吐量,又不會增加用戶和節點運營者負擔的協議。

報告:Coinbase的股票可能正處于多頭和空頭之間的拉鋸戰中:金色財經報道,在遭受熊市重創后,加密貨幣交易所Coinbase Global (COIN) 的股票可能正處于多頭和空頭之間的拉鋸戰中。今年到目前為止,Coinbase的股價已下跌超過 70%,而 VanEck 數字轉型 ETF (DAPP) 下跌了67%,而比特幣的價格下跌了約50%。加密貨幣的冬天、激烈的競爭和最近的監管動蕩共同導致了該平臺的低迷。數據顯示,包括Ark Invest、交易所交易基金發行人Exchange Traded Concepts、Cullinan Associates 和Refined Wealth Management在內的許多機構投資者在第二季度共購買了260萬股Coinbase。然而,數據公布幾天后,Ark Invest公司披露其已售出超過 140 萬股。[2022/7/30 2:47:17]

:我們想要提高以太坊的可擴展性,又不想改變其信任和成本假設。我們該怎么做?

:可以嘗試降低現有操作的成本。不過,說起來容易做起來難,我們先來看一下以太坊的架構:

以太坊網絡中的每個節點目前都存儲并執行來自用戶的每筆事務。事務是在EVM中執行的,并與EVM的狀態進行交互。常見的智能合約優化技術主要聚焦于在最大程度上減少與狀態交互的次數,但是它們起到的作用很有限。

Anchor協議因Terra新鏈啟動被利用,導致損失約80萬美元:5月29日消息,在Terra新鏈啟動后,LUNC(Luna Classic)的價格預言機達到5美元,而實際價格遠低于5美元,Anchor平臺一名用戶注意到該漏洞,存入大約2000萬個Lido Bonded Luna代幣,平臺認為這是1億美元,實際價值應該在20萬美元左右,用戶借出4000萬UST,提取并獲利約80萬美元。(U.Today)[2022/5/30 3:49:18]

:是否存在不與狀態交互就能達成交互的方法,以此降低資源成本?

:在極端情況下,我們是否可以將所有執行都轉移到鏈下,并將數據保存在鏈上?我們可以引入第三方,即,排序者,來做到這點。排序者負責在本地存儲并執行用戶提交的事務。為了保持系統的活性,排序者會定期將它們收到的事務的默克爾根以及狀態根提交到以太坊上。這個思路是正確的,因為O(N)筆鏈下事務只需在以太坊上存儲O(1)的狀態數據。

:通過使用排序者執行鏈下計算,只將默克爾根發布到鏈上,我們就能增強以太坊的可擴展性了是嗎?

:是的。

:也就是說,只要我們選擇了排序者,就能大幅降低轉賬成本。那用戶怎么存錢進去呢?

:你在以太坊區塊鏈上把錢存進某個合約,就能加入這樣的系統了。排序者會將相應的存款記在你的名下。用戶只需要發送一筆事務稱“我想要取出3ETH,我當前的賬戶余額大于3ETH,這是證明”,就可以取出資金。即使L1上沒有該用戶的實際狀態,該用戶也可以提供默克爾證明并引用排序者發布的狀態根來證明自己在當前狀態下擁有足夠多的資金。

:我們已經確定用戶需要提供默克爾證明才能取出資金。用戶如何獲得構建默克爾證明所需的數據?

:用戶可以要求排序者來提供數據!

:如果總是聯系不上排序者,該怎么辦?

:這種情況可能是因為排序者作惡,或因技術問題掉線,這會導致性能退化。因此,我們必須要求排序者將完整的事務數據提交到鏈上,只用于存儲,不用于執行。這里的目的是實現數據可得性。由于所有數據都永久存儲在以太坊上,即使一個排序者倒下了,新的排序者也可以從以太坊上重新找回所有與Layer2相關的數據,重新構建最新的L2狀態,并接替上一個排序者的工作。

:如果排序者在線卻拒絕向我提供默克爾證明數據,我可以從以太坊上下載這些數據對嗎?

:對的,你可以自己同步一個以太坊節點,也可以從眾多節點托管服務提供商中選擇一家。

:我還有個不明白的地方……如何將數據存儲在以太坊上卻不執行它?難道不是每筆事務都要經過EVM執行的嗎?

:假設你提交了10筆A向B轉ETH的事務。執行每筆事務需要執行以下操作:增加A的nonce,減少A的余額,并增加B的余額。這需要多次寫入和讀取世界狀態。你可以將所有事務的編碼發送至智能合約的

publish(bytes_transactions)public{}

函數。請注意,這個函數的函數體是空的!也就是說,如此發布的事務數據是不會被解釋、執行或訪問的。它只存儲在區塊鏈的歷史日志中。

:我們能信任排序者嗎?如果排序者發布非法的狀態轉換怎么辦?

:無論排序者何時發布一批狀態轉換,都會有“爭議期”。在“爭議期”內,任何人都可以發布“欺詐證明”來證明其中某個狀態轉換是無效的。欺詐證明就是通過重放導致鏈上發生狀態轉換的事務,并將得到的狀態根與排序者發布的狀態根進行對比。如果兩個狀態根不同,則欺詐證明成功,狀態轉換被取消。跟在該無效狀態轉換后面的狀態轉換也會被取消。爭議期一過,就無法再對事務提出爭議,即,事務被敲定。

:等等!你之前明明說過,只要會增加成本,或引入新的信任假設,就是不可行的可擴展性方案。你這里提到的方案不是要假設時刻有人會報告欺詐嗎?

:沒錯。我們假設有一組被稱為“驗證者”的實體負責監控欺詐行為。如果Layer1和Layer2之間出現狀態不匹配的情況,驗證者就會發布欺詐證明。我們還假設驗證者能夠在爭議期內將其欺詐證明發布到以太坊區塊鏈上。我們認為,驗證者的存在是一個弱假設。想象一下,如果有數萬名用戶采用該方案,你只需要1個人來擔任驗證者的角色。聽起來不是那么不切實際吧!另外,改變以太坊的信任模型,或增加運行以太坊節點的成本是一個強假設,會做出我們不想要的改變。這就是我們的中心化可擴展性定義中的“幾乎不會改變底層系統的設想”的意思。

:我同意會有人擔任驗證者的角色,因為這個新的解決方案牽涉到很多人的利益。但是,具體怎樣還得取決于實際成本。那么,運行驗證者和排序者需要消耗多少資源?

:排序者和驗證者必須運行一個以太坊全節點,以及一個L2全節點來生成L2狀態。驗證者運行創建欺詐證明的軟件,排序者運行打包并發布用戶事務的軟件。

:就這些嗎?

:沒錯!恭喜!你已經重新發現了OptimisticRollup,這個2019至2021年最有前景的可擴展性方案。我可沒有在說大話,這是以太坊社區經過多年研究得出的成果。也就是你在這段簡短的對話中聽到的。

注:

:我們建議讀者閱讀Vitalik的雄文《區塊鏈資源定價》。

:請注意,存儲“狀態”的成本比存儲原始事務數據的更高。

:OptimisticRollup就是“optimisticcontract”和“onchaindataavailability”的合體。

原文鏈接:

https://research.paradigm.xyz/rollups

作者:GeorgiosKonstantopoulos

翻譯&校對:

閔敏&

阿劍

Tags:以太坊GASTIC區塊鏈以太坊交易一次多少手續費UniDexGasCrypticCoin區塊鏈上班都是干什么的

ETH
楊凱:DeFi 為什么會如此火爆?_EFI:CEFI

隨著區塊鏈技術的出現,金融行業的服務有了很大的進步。區塊鏈已經給加密貨幣行業注入了活力,而在區塊鏈之上的DeFi的出現則給行業帶來了更大的賦能.

1900/1/1 0:00:00
Symon Ho:Web3開發者成為商人_WEB:web3.0幣現價多少錢

本文來自筆者對SymonHo文稿的翻譯。SymonHo是波卡平行鏈項目TrustBase的CTO,作為一名全棧工程開發師,SymonHo關于Web3.0表達了他的看法,一點哲思點破了這個世界正在.

1900/1/1 0:00:00
EOS柚子利好大漲唯一生態DeFi已經啟動_SWAP:Chainswap

EOS柚子逆勢上漲很多人在問有什么利好?首先是很多人聽說“灰度”準備買EOS柚子,這個無疑是個利好。畢竟柚子EOS已經橫盤很長時間.

1900/1/1 0:00:00
回首2020年比特幣五大趨勢_比特幣:ELLA

比特幣由于其固定供應而成為稀缺資產。這是完全無彈性的,因為需求的增加不會轉化為供應的增加。價格是改變需求的唯一閥門。比特幣有一個供應時間表和2100萬個單位的供應上限.

1900/1/1 0:00:00
林軒論幣:2.7比特幣行情 行情回暖 能否再創新高_以太坊:NFT

緣來不拒,緣走不留,茫茫人海相識成為朋友也是一種緣分。素不相識的投資朋友只因看了我晨曦的文章信任我,所以每位找到我的投資朋友我都會給予最大的幫助,讓這份信任變的更有價值.

1900/1/1 0:00:00
馬斯克和狗狗幣的故事開始了_DOGE:xdoge幣最新消息

2021年最牛氣的山寨幣——DOGE。實際DOGE的誕生源于加密社區的小費文化實際上也是自嘲文化,那么DOGE是什么呢?在這里先做個簡單的介紹吧!DOGE幣誕生于2013年12月12日,DOGE.

1900/1/1 0:00:00
ads