關於並行,你需要知道的一切

2024-11-28 16:11:26

撰文:Tia,Techub News

區塊鏈因其去中心化的設計而犧牲了效率,因此提升執行速度一直是急需解決的問題之一。區塊鏈的「執行層」是處理每一筆交易並將其加入鏈中的關鍵部分。為了加速處理能力,在執行層進行提升成為核心策略之一,而並行執行正是這一方面的重要突破。

傳統的區塊鏈通常採用串行方式逐筆處理交易,這使得交易速度受到很大限制,尤其在交易密集的網絡中會引發擁堵。然而,通過並行執行,多個交易可以同時處理,從而大幅提高執行效率並減輕鏈上壓力。

為了更好地了解什么是並行,我們將先從執行开始介紹,並以 Merge 後 PBS 模式下的以太坊為例,來解釋一下什么是執行,同時展示執行在整個交易生命周期中所處的位置。

交易執行的具體環節

  1. 交易進入內存池並被篩選和排序:這是交易被提交後的預處理階段,包含了 Mempool、Searcher 和 Builder 的交互,完成對交易的篩選和排序。

  1. Builder 構建區塊(但不執行):Builder 將有利可圖的交易排列成一個區塊,以完成對交易的打包和排序。

  1. Proposer 驗證並提交區塊:區塊構建完成後,Builder 會將區塊的提案發送給 Proposer。Proposer 對區塊的結構和交易內容進行驗證,然後正式將區塊提交到網絡上,以开始執行。

  1. 執行交易:區塊提交後,節點逐筆執行區塊內的交易。這是狀態更新的關鍵階段,每筆交易都會觸發智能合約調用、账戶余額變化或狀態變更。

  1. 見證者見證:驗證者對區塊的執行結果和狀態根進行見證,並將其作為最終確認。這確保了區塊在執行層的真實性和有效性,並防止不一致性。

  1. 狀態同步:每個節點會將區塊的執行結果(如账戶余額、合約狀態更新等)同步到自己的本地狀態,執行每筆交易後,節點計算並存儲一個新的狀態根,用以在下一個區塊中作為初始狀態。

當然,這只是以區塊為單位的交易的狀態同步,為了保持最新的鏈上狀態,通常情況下,節點會逐個區塊同步數據,並持續驗證區塊和狀態。但如果要達到 POS 機制下的最終性,還需要聚合者將每個 Slot 中的見證者籤名聚合成一個完整的籤名,並將其傳遞到下一個 Slot 的提議者處,並且驗證者需要在經過一個 Epoch 後,基於投票數量確認該 Epoch 內的所有區塊的狀態,形成臨時的共識狀態檢查點。當連續兩個 Epoch 獲得大多數驗證者的見證支持後,區塊和交易才會達成最終性。

從交易的整個生命周期來看,執行發生在 Proposer 對 Builder 發送來的區塊的結構和交易內容進行驗證後。實際執行過程需要對交易逐筆處理,並對相應的账戶或合約狀態進行更新。所有交易執行完畢後,Proposer 會計算出一個新的狀態根(默克爾根),這是對當前區塊所有交易的執行結果和最終全局狀態的總結。通俗來說,完整的區塊執行過程包括把以太坊從前一個狀態變成下一個狀態的過程中需要完成的一系列計算,從每個交易的執行到默克爾根的計算。

順序執行

與並行相對的是順序執行,也就是目前區塊鏈較為通用的執行方式。通常,交易會按照順序逐步執行。當一筆交易完成執行後,以太坊會將账戶狀態及相關信息(例如余額、合約存儲數據)更新至账戶狀態樹中,新的账戶狀態哈希被生成。所有账戶狀態樹完成更新後,就會形成被稱為狀態默克爾根的狀態樹的根節點哈希。在完成狀態默克爾根、交易默克爾根和收據默克爾根後,區塊頭就會進行哈希計算,生成該區塊的區塊哈希。

而在這其中,交易的執行順序至關重要。由於默克爾樹是哈希值的二叉樹,不同順序下形成的默克爾根值會不同。

並行執行

在並行執行的環境下,節點會嘗試對區塊中的交易進行並行處理。並不是按照順序一筆一筆地執行交易,而是將交易分配到不同的「執行路徑」上,使它們能同時執行。通過並行執行,系統能夠更高效地處理區塊中的交易,提高吞吐量。

所有交易執行完成後,節點會將執行結果(即交易影響的狀態更新)匯總,形成一個新的區塊狀態。這個狀態會被添加到區塊鏈上,代表鏈上最新的全局狀態。

狀態衝突

由於並行會在不同路徑同時處理交易,因此並行的一大難點就是狀態衝突。即可能存在多個交易在同一時間段內對區塊鏈上的同一部分數據(狀態)進行讀取或寫入操作的情況。這種情況如果處理不當,會導致執行結果不確定。因為狀態的更新順序不同,最終的計算結果也會不同。舉個例子,

假設有兩個交易,交易 A 和交易 B,它們都試圖對同一個账戶的余額進行更新操作:

  • 交易 A:增加账戶余額 10。

  • 交易 B:增加账戶余額 20。

账戶初始余額為 100。

如果我們串行執行,執行順序的結果是確定的:

1. 先執行交易 A,再執行交易 B:

  • 账戶余額先增加 10,變為 110。

  • 再增加 20,最終變為 130。

2. 先執行交易 B,再執行交易 A:

  • 账戶余額先增加 20,變為 120。

  • 再增加 10,最終變為 130。

在這兩種順序中,最終余額都是 130,因為系統確保了交易執行的順序一致性。

但在並行執行環境下,交易 A 和交易 B 可能同時讀取初始余額 100 並進行各自的運算:

1. 交易 A 讀取到余額為 100,計算後更新余額為 110。

2. 交易 B 也讀取到余額為 100,計算後更新余額為 120。

在這種情況下,由於交易同時執行,導致最終余額只更新為 120,而不是 130,因為交易 A 和交易 B 的操作「覆蓋」了對方的結果,產生了狀態衝突。

這類狀態衝突問題通常被叫做「數據覆蓋」,即當交易試圖同時修改相同的數據時,可能會相互覆蓋對方的計算結果,導致最終狀態不正確。另外一種狀態衝突可能會導致的問題是無法保證執行順序。由於多個交易在不同的時間段完成操作,會造成不同的執行順序。順序不同,可能會導致不同的計算結果,從而使結果不確定。

為了避免這種不確定性,區塊鏈並行執行系統通常會引入一些衝突檢測和回滾機制,或提前對交易進行依賴性分析,確保它們在不影響最終狀態一致性的情況下並行執行。

樂觀並行與確定性並行

有兩種方法方式來對待可能存在的狀態衝突問題:確定性並行和樂觀並行。這兩種模式在效率和設計復雜性上各有權衡。

確定性並行需要提前聲明狀態訪問,驗證者或 sequencer 會在交易排序時檢查聲明的狀態訪問。如果有多個交易試圖寫入同一狀態,會將這些交易標記為衝突,避免同時執行。不同的鏈具體實現提前聲明狀態訪問的形式不同,但一般包括以下幾種方式:

  • 通過合約規範約束:开發者在智能合約中直接規定狀態訪問範圍。例如,ERC-20 代幣轉账需要訪問發送方和接收方的余額字段。

  • 通過交易結構化數據聲明:交易中添加專門字段來標注狀態訪問。

  • 通過編譯器分析:高級語言的編譯器可以靜態分析合約代碼,自動生成狀態訪問集合。

  • 通過框架強制聲明:某些框架要求开發者在調用函數時顯式指定需要訪問的狀態

樂觀並行則會樂觀地先處理交易,等到衝突發生時,再將受影響的交易按順序重新執行。為了盡可能避免衝突情況的發生,樂觀並行設計的核心是通過歷史數據、靜態分析等對狀態進行快速預判和假設。即系統在不完全驗證的情況下,假設某些操作或狀態更新是有效的,盡量避免等待所有驗證過程,以此提高性能和吞吐量。

雖然樂觀並行能通過一些對狀態的快速預判和假設來盡可能避免衝突發生,但還是會有一些無法避免的挑战,特別是涉及合約執行或跨鏈交易,如果衝突頻繁發生,重新執行可能顯著拖慢系統性能,並增加計算資源消耗。

確定性並行則通過在交易前進行狀態依賴性檢查以避免樂觀並行可能出現的衝突情況,但由於需要在交易提交前准確聲明狀態依賴,這對开發者提出更高要求,從而增加了實現的復雜性。

EVM 並行困境

對待狀態衝突不僅有確定性和樂觀之分,在實現並行的具體過程中,還需要從鏈數據庫架構的角度進行考慮。並行中的狀態衝突問題在默克爾樹架構下的 EVM 中就尤為困難。默克爾樹是一個分層哈希結構,在每次交易對某個狀態數據進行修改後,默克爾樹的根哈希值也需要更新。這種更新過程是遞歸的,從葉子節點向上逐層計算直至根節點。由於哈希是不可逆的,即只有當下層的數據變更完成後才能計算上層,這種特性導致它很難並行更新。

如果兩個交易並行執行並訪問同一個狀態(如账戶余額),就會造成默克爾樹節點的衝突。而解決這種衝突通常需要額外的事務管理機制,確保在多個分支中都能得到一致的根哈希值。這對 EVM 來說並不容易實現,因為它需要在並行化與狀態一致性間做取舍。

非 EVM 並行解決方案

Solana

不同於以太坊的全局狀態樹,Solana 採用了账戶模型。每個账戶是獨立的存儲空間,存儲在账本中,因此避免了路徑衝突問題。

Solana 是確定性並行。在 Solana 中,每筆交易需要在提交時明確聲明將訪問的账戶和所需的訪問權限(只讀或讀寫)。這種設計讓區塊鏈節點可以在交易執行之前,提前分析每筆交易需要訪問的資源。因為交易在开始執行前已明確所有的账戶依賴關系,節點可以判斷哪些交易會訪問相同的账戶,哪些交易可以安全地並行執行,從而實現智能調度,避免衝突,從而實現並行調度的基礎。

由於每筆交易在執行前就已聲明了需要訪問的账戶和權限,Solana 可以檢查交易之間是否存在账戶依賴關系(Sealevel 模型)。交易之間如果沒有共享的讀寫账戶,系統就可以把它們分配到不同的處理器上並行執行。

Aptos

Aptos 的並行執行設計與以太坊有很大的不同,它在架構和機制上做出了一些關鍵創新,主要體現在账戶模型和狀態存儲。

以太坊在執行交易時需要頻繁更新全局狀態樹(MPT)。所有账戶、合約的狀態都存儲在一個共享的狀態樹中,任何交易都需要訪問和更新這棵狀態樹的一部分。而 Aptos 則通過將账戶劃分為獨立的狀態單元,每個對象是一個獨立的鍵值對,對象之間可以獨立存在,彼此互不影響,只有明確引用關系時才會關聯。對象之間沒有公共的樹路徑,不會出現鎖競爭,可以完全並行。

Aptos 的底層數據結構為 Jellyfish Merkle Tree。每個對象的狀態最終存儲在 JMT 中,作為獨立的鍵值對。不同於以太坊的 MPT,Jellyfish Merkle Tree 以一種完全二叉樹結構的形式,這種形式使得節點的存儲路徑和查詢路徑被簡化,大幅降低了驗證時間。並且,每個账戶在樹中的位置是固定的,且樹中的節點是獨立存儲的,允許多個账戶的更新和查找並行進行。

Aptos 是樂觀並行,它不需要預先提供聲明的所有账戶的依賴關系。為此,Aptos 使用 Block-STM,Block-STM 會利用預設的交易順序來估計依賴性,從而減少中止次數。

並行 EVM

與非 EVM 並行相比,並行 EVM 在處理狀態依賴性、衝突檢測、Gas 管理和回滾機制等問題時,面臨的技術難度較大。為了更好地理解這一點,我們可以參考一些並行 EVM 項目(如 Sui、Monad、Canto)如何解決這些問題。

Sui

Sui 和 Aptos 一樣,也是使用對象模型來處理狀態,採用每個對象(例如账戶、智能合約狀態)作為獨立的資源,這些對象通過對象唯一標識符來區分。當交易涉及不同的對象時,這些交易可以並行處理,因為它們對不同的狀態進行操作,不會產生直接的衝突。

雖然 Sui 使用對象模型來管理狀態,然而,為了兼容 EVM,Sui 的架構通過額外的適配層或抽象機制,來橋接對象模型和 EVM 的账戶模型。

在 Sui 中,事務的調度使用樂觀並行策略,假設事務之間沒有衝突。如果衝突發生,系統會使用回滾機制來恢復狀態。

Sui 使用了對象模型和狀態隔離技術,能有效避免狀態依賴性問題。每個對象作為獨立的資源,不同的交易可以並行執行,從而提高了吞吐量和效率。但這種方法的 trade-off 是對象模型的復雜性和回滾機制的开銷。如果交易之間發生衝突,需要對部分狀態進行回滾,這會增加系統的負擔,並且可能影響並行處理的效率。相較於非 EVM 並行系統(如 Solana),Sui 需要更多的計算和存儲資源來維持高效的並行性。

Monad

與 Sui 一樣,Monad 採用的也是樂觀並行。但 Monad 的樂觀並行在具體交易執行前還是會對一些具有依賴關系的交易進行預測,預測主要通過 Monad 的靜態代碼分析器來完成。預測需要對狀態進行訪問,而以太坊數據庫中存儲狀態的方式使得訪問狀態非常困難,為了使得並行在狀態讀取的過程更具效率,Monad 還重構了數據庫。

Monad 狀態樹按分區進行劃分,每個分區維護自己的狀態子樹。更新時只需修改相關分片,無需重建整個狀態樹。通過狀態索引表快速定位分區中的狀態,減少分區間的交互。

區塊鏈 TPS 節點硬件要求 虛擬機 特點
Solana 65,000+ 12 核 CPU,256GB RAM,驗證者節點 500GB SSD,歸檔節點 1TB SSD,並最好再預留 500 GB 給操作系統 Solana VM 高並發支持,採用 Proof of History (PoH),非常高的吞吐量,較輕的共識機制
Aptos 160,000+ 32 核 CPU,64GB+ RAM,3.0 TB SSD 存儲 Move VM 基於 Move 語言,支持並行執行,優化高吞吐量和低延遲
Sui 120,000+ 8 核 CPU,128GB RAM,4 TB NVMe SSD 存儲 Sui VM 並行執行,基於資源的模型,支持低延遲高吞吐量
Monad 10000+ 16 核 CPU,32GB RAM,2 TB NVMe SSD 存儲 EVM(兼容性層) 高並行性能,通過異步執行和更輕量的 EVM 虛擬機設計優化吞吐量
以太坊(Merge 後) 30-100+ 4 核 CPU,32GB RAM,4TB SSD 存儲 EVM 傳統智能合約平臺,Merge 後轉為 Proof of Stake,仍支持有限的並行性

小結

並行的核心是以多路徑執行的方式提高執行層執行效率,而為了實現多路徑執行,鏈則需要進行一系列如衝突檢測和回滾機制以確保它們在不影響最終狀態一致性的情況下並行執行,並對數據庫進行一定程度的改良。

當然,執行層效率的提高不局限於並行這一種方式,執行環節的優化還可以通過降低一筆交易對數據庫需要的讀寫操作來完成。而整個鏈速度提升涉及的範圍則更為廣泛,還包括了共識層效率的提升。

每個技術背後都有屬於其特定的限制條件。並行僅是提升效率的方式之一,最終決定是否使用該技術還需要考慮對於开發者是否友好,是否能夠以不犧牲去中心化的方式完成等等。技術的堆疊並非越多越好,至少,對於以太坊而言,並行並沒有那么那么具有吸引力,如果單從提升效率的角度出發,加入並行對於以太坊而言並非是最優解,無論是從簡潔性考慮還是以以太坊目前 Rollup 為中心的路线圖來考慮。

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播信息之目的,不構成任何投資建議,如有侵權行為,請第一時間聯絡我們修改或刪除,多謝。

推薦文章

動區週報》比特幣盤整、臺灣區塊鏈年度最有影響力 30 人、多機構 2025 年預測..

本週(12/29-1/04)重要大事速覽 比特幣動態 :美國 4 個月內會有州政府宣布 購買比特幣...

Arthur Wang
3 1小時前

FTX還錢計劃生效!債權人1/20前需完成交易所帳號登記,首批退款60天內發放

已 破產交易所 FTX 在去年 12 月宣布,其於去年 10 月經法院批准的重組計畫 將於 202...

DaFi Weaver
3 1小時前

市場絕對熱點,有哪些AI NFT項目值得關注?

作者:Cookie AI 無疑是近段時間 Crypto 市場的絕對主线,各種 AI 概念代幣紛紛上...

3 1小時前

萬字長文探討跨鏈解決方案,如何讓跨鏈代幣具有可互換性?

撰文:Alex Hook、Emmanuel Awosika 編譯:Glendon,Techub N...

3 1小時前

10K Ventures年報(上):回顧2024

年報分上下兩篇 本篇分享我們對 2024 年的思考,不構成投資建議。 本篇主要涵蓋 2024 年的...

星球日報
3 1小時前

傳統企業要不要購买比特幣?

作者:Chi Anh、Ryan Yoon 和 Yoon Lee,Tiger Research 編譯...

3 1小時前