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

兩全其美的 zk rollup 預共識機制_ROLL

Author:

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

1)太長不看:

本文概述了一種預共識機制,可以實現即時終局性并減少驗證 gas 成本,同時不影響 zkRollup 的即時資金退出。

2)背景和動機:

在承諾間隔足夠短(如 10 分鐘)的情況下,zkRollup 可以實現即時終局性。在這個方案中,聚合者的信任風險會隨間隔時間增長而增加,實現終局性的成本(如果是 Groth16 算法,每個承諾的驗證 gas 成本超過 20 萬 gas)會隨間隔時間延長而降低。

首先說明 zkRollup 的配對驗證成本超過 20 萬 gas(價值 100 至 500 美元)。也就是說,在 zkRollup 的每個承諾間隔期內,聚合者都需要花費這么多 gas 來驗證并敲定承諾。

我們不能忽略這一成本,因為 zkRollup 的承諾間隔很短。我們需要承諾來實現即時退出的終局性。只要承諾間隔很短,且惡意聚合者回滾交易的積極性不高,我們就可以實現即時終局性(經濟終局性,零確認交易)。

加密銀行Wallbit因美國經濟制裁將取消對委內瑞拉用戶服務:2月28日消息,支持加密貨幣服務的銀行Wallbit,受美國經濟制裁影響將停止提供對委內瑞納境內的委內瑞拉用戶的服務,正在呼吁關閉其開設的所有賬戶,并通知用戶盡快提取資金,并未表明賬戶關閉的日期。

此外,居住在國外的委內瑞拉用戶仍然可以使用其服務,但在這種情況下他們應該聯系公司支持。這種情況可能會影響使用該平臺在國外收取工資并將其轉換為加密貨幣的委內瑞拉自由職業者。[2023/2/28 12:34:46]

盡管我們可以使用遞歸零知識證明和高效的證明計算系統來聚合多個交易,我們也很難改變承諾間隔。如果我們盲目延長承諾間隔,就會影響安全性。

然后,我們需要思考如何在 zkRollup 中實現安全的即時終局性和較長的驗證間隔。

Coinbase將上線Access Protocol(ACS):據官方推特,Coinbase宣布將上線Access Protocol(ACS)。如果滿足流動性條件,交易將于太平洋冬令時2月15日9:00(北京時間2月16日1:00)開始。如果建立了足夠的該資產供應, ACS-USD交易對的交易將分階段開放。

注意:Coinbase僅在Solana網絡上支持上述代幣,不要通過其他網絡發送此資產,否則資金可能會丟失。

Solana生態內容貨幣化協議Access Protocol官方昨日宣布,將于2月15日在Solana區塊鏈上啟動,初始協議通貨膨脹率將設置為2%,未來幾個月將調整到5%。[2023/2/15 12:07:21]

3)方法:

聚合者的運行成本源自合約上零知識證明驗證的 gas 成本高且承諾間隔短。

Bitfarms在阿根廷的大型礦場開始運營:金色財經報道,比特幣礦企Bitfarms位于阿根廷的大型采礦場已經開始運營。該礦場于9月16日啟動,目前在第一階段有10兆瓦(MW)的采礦電力,此后將擴大運營規模以在明年全面投入運營。Bitfarms預計它將為實現該公司2023年的采礦目標貢獻50兆瓦。

據該公司稱,這將是其最現代化的,也是最大的采礦業務。(Bitcoin.com)[2022/9/19 7:05:08]

因此,我們可以在不影響安全性和可用性的情況下延長驗證間隔。

3.1)第一步:跳過零知識證明配對驗證

首先,我們最容易想到的解決方案就是跳過配對計算,并引入針對承諾的簡單欺詐證明。

聚合者向合約提交證明或驗證 zkRollup 承諾所需的任何東西,但這時不執行配對計算,也就不需要支付 20 萬 gas。一段時間過后,這個承諾就會得到驗證;這個承諾中的每個狀態將成為下一個承諾的公共輸入。聚合者需要鎖定一些以太幣來激勵驗證者。一旦驗證者發現欺詐行為,聚合者就會受到懲罰。

國際帆船賽事SailGP將在NEAR上推出NFT:6月16日消息,國際帆船賽事 SailGP 將在 NEAR 上推出 NFT,共包含 4 個系列,包括地球日海報、SailGP 城市系列商品中的藝術品、SailGP 的獲獎攝影作品以及作為粉絲參與 SailGP NFT 入場券的 NFT。[2022/6/16 4:31:36]

承諾就是公共輸入、零知識證明數據、上一個狀態根、下一個狀態根、交易哈希和聚合者地址這幾項的哈希值。

原像由鏈上事件提供,承諾保存在合約存儲內。

這種方法具有很大的優勢。

每個人都可以成為瞭望塔,等同于 Optimistic Rollup 中的“驗證者”,無需運行全節點或進行任何特殊的起步設置。

數據可得性問題不會發生,因為驗證或執行欺詐證明所需的一切數據都在鏈上發出的事件中。執行欺詐證明時,我們不需要 Layer 2 交易數據及交易結果,因為這些數據全都包含在了零知識證明的公共輸入和證明中。

如果惡意聚合者提交了惡意默克爾根,并放棄了所有交易數據和默克爾樹數據,我們不需要運行全節點來進行欺詐證明。我們只需檢查零知識證明數據,并執行配對驗證函數,即可發現這類惡意行為。

但是,上述方法存在安全性問題。

如果 Layer 1 上發生 51% 攻擊,將惡意默克爾根合法化,我們很難阻止。

由于 51% 攻擊的執行成本隨底層區塊鏈的出塊時間增加而增加,我們需要足夠長的驗證期限,才能有效提高 51% 攻擊的難度。理想的驗證期限是 7 天,因為 ORU 的退出期限也是 7 天,這可以根據挖礦成本和實際的攻擊獎勵計算得到。

在這種情況下,我們沒有理由舍 ORU 而取上述方案。

3.2)第二步:無需零知識證明驗證的預共識承諾,通過遞歸零知識證明配對實現終局性

我們可以通過以下方式解決上述安全性問題。

我們將這個沒有經過零知識證明驗證的承諾視為預共識。預共識會通過零知識證明驗證限制終局性。

(consensus commit ) => (pre-consensus commit ) => (pre-consensus commit ) => …. => (pre-consensus commit ) => (consensus commit )

所有預共識承諾都會通過配對來限制共識。因此,Layer 2 用戶可以享受安全的即時交易終局性。我們需要使用帶有遞歸零知識證明的所有預共識承諾來驗證共識承諾。這里有兩個電路:預共識電路和遞歸電路。預共識電路包含采用 zkRollup 方案的 dApp 的邏輯。遞歸電路只需要從 Layer 1 中獲取預共識數據作為公共輸入。

遞歸零知識證明可以用來對一段時間內的預共識進行水平合并:與此同時,它也可以用來將大量交易垂直聚合到預共識承諾中。

如果說任何虛假的預共識承諾都會影響帶有配對的共識驗證,我們總是可以通過零知識證明配對其進行欺詐證明。一旦證明成功,聚合者就會使用零知識證明驗證者函數將該承諾刪除,然后重新開始進行交易聚合并創建預共識承諾。

如果急的話,資產持有者可以花 20 萬 gas 通過預共識來達成共識,然后就可以立即退出。(當然,他們也可以等待聚合者來達成共識。)正如“第一步”中提到的那樣,他們不需要任何特殊設置,即可實現共識終局性,因為所有輸入都已聚合,而且可以通過鏈上事件搜索到。無論驗證多少預共識承諾證明,遞歸驗證的 gas 成本都不會增加,因為這些證明將被哈希到條目哈希中。

51% 攻擊者無法敲定惡意默克爾根,因為每個根最終都會通過由 zk電路實現的合約代碼邏輯在鏈上進行驗證。

4)總結:

這種帶有欺詐證明的預共識協議及相關數據可訪問性可以讓 zkRollup 擁有較長的承諾間隔(如 6 小時)。這種方法可以大量節省驗證計算所需的 gas 成本。

Tags:ROLGASROLLKROTROLLBNB幣UGAS幣BenjiRollsSILKROAD

火幣下載
如果比特幣突破30萬美元 市場還會有人拋售它嗎?_CAF

丹·海爾德(Dan Held)是Kraken的業務增長負責人,他最近談到了與“比特幣的超級周期”有關的重要假設.

1900/1/1 0:00:00
印比特聯合創始人朱砝:四川和新疆始終是世界挖礦的中心_USDC

金色財經現場報道,4月24日,由印比特主辦、金色財經和易礦聯合主辦,珠海市橫琴新區數鏈數字金融研究院指導的《2021新基建區塊鏈峰會》在成都召開.

1900/1/1 0:00:00
從 zkSync 看以太坊 Layer 2 的機遇和挑戰_ZKS

Q1:最近許多用戶關注到?zkSync?空投,zkSync?如何考慮?Native?Token?機制和發放計劃呢?Alex:我們認為,初始代幣的去中心化,對于任何加密協議來說都是至關重要的.

1900/1/1 0:00:00
如何打敗以太坊清道夫 挽救你的資產?_SHB

你沒有過這樣的經歷:將一筆資金發送到某個賬戶后,這筆資金卻不翼而飛?你可能是遭了“清道夫”的手。我們來幫你解除危機.

1900/1/1 0:00:00
10年前的今天 比特幣創造者中本聰發送了最后一封電子郵件_RIZZ

摘要:十年前的今天,2011年4月26日,比特幣創始人中本聰(Satoshi Nakamoto)向其他開發人員發送了最后一封電子郵件,他在郵件中明確表示,他已經“轉移到其他項目”.

1900/1/1 0:00:00
項目周刊 | 以太坊價格破新高 市值排名升至第25位_比特幣

金色周刊是金色財經推出的一檔每周區塊鏈行業總結欄目,內容涵蓋一周重點新聞、行情與合約數據、礦業信息、項目動態、技術進展等行業動態。本文是項目周刊,帶您一覽本周主流項目以及明星項目的進展.

1900/1/1 0:00:00
ads