什么樣的UTXO可以支持所有以太坊智能合約?

2021-09-10 18:09:48

時至今日,有關 UTXO 模式的局限性,仍有許多誤解廣為流傳;人們聲稱,UTXO 是不可能實現以太坊那樣的智能合約的(或者即使能也非常難)。我們在此提供出一種基於 UTXO 的執行模式,可以支持所有的以太坊智能合約功能模塊(取決於虛擬機的規範)。這些想法都不是全新的,只不過都散落在各種在线聊天裏。對於尚不熟悉這種模型的人來說,這篇文章可以作為介紹和討論這個模型的資源匯總。

背景

前置讀物

  • Bitcoin: A Peer-to-Peer Electronic Cash System, Nakamoto

  • (Ethereum Design Rationale) Accounts and not UTXOs, Buterin

  • (Bitcoin Stack Exchange) UTXO model vs. account/balance model, Wuille

  • The Stateless Client Concept, Buterin

  • EIP-648: Easy parallelizability 25, Buterin

  • Practical parallel transaction validation without state lookups using Merkle accumulators, Adler

  • Intro to CKB Script Programming 1: Validation Model, Xiao

額外讀物

  • State Provider Models in Ethereum 2.0 , Dietrichs et al.

  • Automated Detection of Dynamic State Access in Solidity, Wilson

  • The “Direct Push” model can’t handle stale witnesses, Cloutier

  • Optimizing sparse Merkle trees, Buterin

  • Fraud and Data Availability Proofs: Maximising Light Client Security and Scaling Blockchains with Dishonest Majorities 33, Al-Bassam et al.

  • Zexe: Enabling Decentralized Private Computation 4, Bowe et al.

在 UTXO 模式中實現以太坊式的執行

數據模式

除了我們在傳統的基於 UTXO 的系統裏面熟悉的 coin UTXO(原生貨幣 UTXO)以外,我們定義一種新的 UTXO 類型,contract UTXO(合約 UTXO)。

Coin UTXO 有如下字段:

  1. Coin 的數量

  2. 使用腳本的哈希值(定義了該 UTXO 的所有者)或者所有者

Contract UTXO 由以下字段組成:

  1. Coin 的數量

  2. 合約 ID

  3. 合約代碼哈希值

  4. 存儲根

在實踐中,除了這些字段,肯定還會增添字段或優化這些字段,比如存儲代碼或腳本默克爾樹的樹根(BIP-016),而不是存儲哈希值。我們在這裏僅列舉最基礎的字段,以簡化分析、集中在所需的核心特徵上。

合約的代碼哈希值和存儲根只有使用無狀態執行模式才會用得上。在具有狀態的執行模式中可以省略,但因此需要一個專門用於存儲的 UTXO 類型。

UTXO ID(即每個 UTXO 的唯一標識符,可以在基於鍵值對的數據庫中用作 key)是這個 UTXO 的 outpoint(生產該 UTXO 的交易的 ID 以及該 UXTO 在輸出中的位置索引),或者某種變種(例如,outpoint 及其字段的哈希值)。

注意,在這個模式中,合約 UXTO 沒有定義 “所有者”(即對此 UTXO 具有排他控制權的私鑰),就像以太坊當前的合約一樣。也就是說,合約的代碼要來定義其內部的所有權概念,例如 使用 onlyOwner() 方法。因此,合約 UTXO 是 任何人都可以花費的

執行模式

以太坊虛擬機(EVM)中的智能合約,有三大區別於比特幣腳本的本質特徵:

  1. 狀態元素可以定義自身的修改規則。這個區別是衆所周知的,只不過被不精確地表達為以太坊可以上傳持久的代碼,但這只是一個手段,而非目的。

  2. 用戶可以與合約交互。這就意味着以太坊式的合約沒有固有的所有權概念。

  3. 合約可以與其它合約交互。

那我們如何能在 UTXO 模式上實現這些特徵呢?

第一點很簡單:我們可以使用 covenants 來強制執行合約 UTXO:當合約 UXTO 在一筆交易中使用時,必須創建一個新的、帶有特定花費條件的 UTXO(且只能創建一個);具體來說,就是合約代碼相同,但是狀態根更新了(取決於交易執行的結果)的 UTXO。一個例外是合約的銷毀,如果需要這個功能的話。

用了 covenants,用戶自然而然可以跟合約交互,因為合約 UTXO 是人人可用的,任何用戶單獨與任意數量的合約交互。

然後,還得讓合約能夠跟其它合約交互(結果是,用戶可以同時與許多合約交互)。這個也簡單,只需讓多個合約的 UTXO 都能在同一筆交易中使用,即可。從另一個角度看,交易聲明了自己將觸及哪些合約(且,在账戶模型中,還可額外聲明將觸及哪些狀態對象)。這就是所謂的 “嚴格訪問列表”。

最後,我們需要討論如何生成合約和更新合約。合約 UTXO 可以使用一個操作碼來創建,創建時會確定性地分配一個密碼學上唯一的合約 ID,例如類似於以太坊 CREATE2 這樣的操作碼。作為一個合約 UTXO,在使用和重生時,其合約 ID 保持不變,但其 UTXO ID 將變化,而且每次交易後都會不同,因為 UTXO 的 ID 是由 outpoint 決定的。

交易格式

交易是一個包含下列內容的元組:

  1. 輸入:一些唯一標識符,表明要消耗哪些 UTXO,並提供不可變形(non-malleable)的數據來解鎖 coin 或者與合約交互。

  2. 輸出:定義創建哪些 UTXO。

  3. Gas Price 和 Gas Limit。

  4. Witness:額外的元數據,包括賦予交易合法性的數字籤名以及無狀態的默克爾樹分支。

交易由自身的輸入和輸出來唯一標識,也即籤名的對象僅包括輸入和輸出。Witness 數據是區塊生產者可以改變的。

要讓一個區塊裏面可以多次使用同一個合約,關鍵是合約 UTXO 可以由其合約 ID 來唯一標識(加上其 UTXO ID),即在任何時候,使用某個 ID 的合約都只有一個。因此,用戶只需提供自己的交易會訪問的所有合約的 ID,而不需要提供 UTXO ID。區塊組裝者會提供具體的 UTXO ID,放在 witness 中。Coin UTXO 的花費則與我們今天的用法無二。

最後一件事

精明的讀者可能注意到了,在本文提供的方案中,某些只引用合約 UTXO 作為輸出但不執行操作(也即不消耗 gas)的交易,可能會遇到交易 ID 重合問題。為了避免這一點,一筆交易至少要消耗一個 coin UTXO。

更一般地來說,這個規則也可以放得寬松一些,只要求交易至少一個輸入需要用 UTXO ID 來顯式地指定,這樣只提供合約 UTXO 有時也行。這樣做就支持原生的账戶抽象(EIP-2938)。

還有其它重要的理由支持實施這條規則,包括通過最基本的手續費來實現 DoS 保護,並以動態比例的手續費燃燒的方式實現彈性的區塊大小(EIP-1559)。

UTXO 對比账戶模式的好處

相比账戶模式,使用 UTXO 有許多好處,最主要的是通過並行化來創建更高吞吐量工程實現的潛能

  1. 交易指定了自己會觸及哪個合約,因此不相關的交易就可以並行執行(連生產區塊的節點都可以)。這個在账戶數據模式下使用 “嚴格訪問列表” 也可以實現。

  2. UTXO 數據模式下的交易顯式地說明了其狀態轉換。因此,在非區塊生產者這邊,交易可以並行地驗證,即使它們讀取或者寫入了同一個合約。在本文提出的方案中,生產區塊的節點仍然需要用重疊的訪問列表,按順序地執行交易。

  3. UTXO 數據模式的 nonce(交易流水號)以 outpoint 的形式呈現,所以無需顯式地跟蹤零余額地址的 nonce,但當前的账戶數據模式就需要。

直覺

我們注意到,UTXO 沒有提供任何本質上與账戶不同的功能,也沒有缺失任何基礎功能。這一點可能並不讓人驚訝,因為它們都可以在一個統一的模式下得到描述。不過,UTXO 數據模式提供的內置訪問列表功能可以實現更大的可擴展性。

一個關鍵的直覺是,底層的數據模式與執行模式沒有絕對的關聯,執行模式既可以是具狀態的,也可以是無狀態的;跟合約是否能與另一個合約互動也沒有絕對的關聯。

結論

我們在此提出了一種用 UTXO 數據模式實現通用的、以太坊式富狀態智能合約的方案。這是用 covenants 以及允許合約彼此交互(在同一筆交易中聲明)來實現的。我們注意到,UTXO 數據模式和帶有嚴格訪問列表的账戶數據模式是等價的。

原文鏈接:

https://forum.celestia.org/t/accounts-strict-access-lists-and-utxos/37

作者: John Adler

翻譯: 阿劍

感謝 Mustafa Al-Bassam (musalbas)、James Prestwich (prestwich) 和 Sam Wilson (SamWilsn) 的審閱。

HackMD 鏡像在此:https://hackmd.io/KOJdKANHSvaGC_8IugEAJA 20

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

推薦文章

btc日內再次下跌 短线應當如何處理?

盡管以太坊現貨ETF獲批是個好消息,但市場反應卻不如預期。在消息公布後,以太坊價格出現了小幅下跌,...

加密蓮
242 6個月前

7月23日、BTC(合約)ETH(合約)行情分析及操作策略

昨日收益還是不錯的,日內給出的現價空單分別止盈我們目標點位,恭喜跟上的朋友喫肉。時間一晃到月底了,...

倪老師
238 6個月前

幣圈院士:血與淚的教訓!交易者為何總是撞死在同一棵樹上?

幣圈院士談。交易市場中的幾種“死法” 在幣圈市場鱗次櫛比的海洋,風起雲湧,時常讓人感到驚手不及。在...

幣圈院士
249 6個月前

7月23:Mt. Gox 比特幣錢包在市場緊縮的情況下轉移了價值 28.2 億美元的 BTC

7月23:Mt. Gox 比特幣錢包在市場緊縮的情況下轉移了價值 28.2 億美元的 BTC一個引...

168超神
245 6個月前

悅盈:比特幣68000的空完美落地反彈繼續看跌 以太坊破前高看回撤

一個人的自律中,藏着無限的可能性,你自律的程度,決定着你人生的高度。 人生沒有近路可走,但你走的每...

我是周悅盈
228 6個月前

btc完美盈利 晚間波動較大注意

昨日btc空單完美給到,最大化走出一千七百點空間~ btc: 日內开盤下跌繼續測試66000一线,...

加密蓮
228 6個月前