以太坊已經確認了以Rollup為中心的2.0路線圖,這讓Rollup成為了炙手可熱的技術,也可以說已經成為了layer2擴容的主流技術。如果與零知識證明證明搭配起來,Rollup會是layer2技術里解決方案的集大成者。
但正所謂“沒有絕對安全的系統”,Rollup同樣存在一定安全隱患,以太坊研究者論壇的開發者已經在討論此事。1月20日,以太坊開發者「jchancehud」發布了關于虛擬Rollup攻擊的討論。
以下為關于虛擬Rollup攻擊的討論。經白計劃團隊整理,有所修改和批注。
Rollup的安全風險原因
模擬Rollup攻擊的基本原理是:只要虛擬狀態有效,任何以太坊節點都可以向OptimisticRollup協調員撒謊。而協調員只有在嘗試發送交易或切換以太坊供應商時才會發現這一點。
OptimisticRollup是通過在以太坊網絡上使用calldata存儲塊信息來進行。這各過程允許任何人操作以太坊節點并下載Rollup狀態。但實際上,有些人不會操作他們自己的以太坊節點,而是依靠托管解決方案。
以太坊未確認交易為99,170筆:金色財經消息,據OKLink數據顯示,以太坊未確認交易99,170筆,當前全網算力為275.16TH/s,全網難度為3.65P,當前持幣地址為51,919,690個,同比增加116,338個,24h鏈上交易量為3,185,561.75ETH,當前平均出塊時間為13s。[2020/12/24 16:25:07]
需要驗證有效性
如果要快速低成本地構建有效的Rollup鏈,需要做的是進行交易、構建狀態并將其存儲在以太坊網絡以外的其他位置。當Rollup協調員從以太坊節點接收狀態歷史記錄時,協調員可以通過重播狀態交易來確定數據是否有效。然而,協調員不能確定鏈上是否存在該狀態,最好的辦法是詢問以太坊節點。
如果出現人為攻擊
如果想象一個名為Untrust的以太坊節點服務。Untrust為以太坊dapp提供了低成本的基礎架構。如果他們選擇不信任,則可以查看特定的Rollup并創建虛構的歷史記錄。他們甚至可以通過從某些真實交易中提取通信數據并將其與虛擬交易混合來創建半虛擬歷史。
動態 | FairWin余額被清空,以太坊網絡Gas消耗高飽和狀態解除:據DAppTotal.com數據顯示,昨日(10月01日),以太坊網絡Gas消耗量價值總計510個ETH,Gas利用率占以太坊網絡可承載Gas總量的81.69%。經綜合對比發現,Gas消耗量排名前5的智能合約分別為:SpaceShips(7.13%),ERC20 USDT(5.43%),EtherHonor(3.23%),CodexCoin(3.75%),HyperFair(2.19%)。自08月26日以來,以太坊網絡每日Gas消耗飽和度均在90%以上(高飽和度),持續了超一個月時間,不過昨天飽和度大幅回落至81.69%,主要由于資金盤游戲FairWin合約余額被清空,其對以太坊網絡造成的擁堵也暫告一段落。[2019/10/2]
這樣,他們將創建一個完全不同的當前狀態哈希,但只有在使用Untrust的Rollup運算符去提交一個塊的情況下,這才會被發現。
這種類型的攻擊并不是特別強大。攻擊者無法偽造簽名,不能直接竊取資金,但可以在Rollup中撒謊自己的活動。
動態 | 以太坊未確認交易11867筆:Etherscan.io數據顯示,當前以太坊未確認交易數為11867筆,與昨日相比未確認筆數波動不大,整體以太坊網絡擁堵程度一般。[2019/3/24]
想象一下,Untrust變得更加復雜。他們決定攻擊名為MoneyMover的Rollup。
當收到對MoneyMover地址的請求時,它們會從運行完全獨立的以太坊網絡的節點返回信息。在這個獨立的以太坊網絡中,Untrust鏡像了大多數交易,并在需要時注入自己的交易。
現在說Untrust找到一個使用MoneyMoverRollup付款的網站。該網站運行自己的MoneyMover協調員,該協調員連接Untrust以訪問以太坊網絡。
Untrust可能會在其鏡像網絡中創建虛構的交易,MoneyMover協調員將其解釋為有效。由于MoneyMover協調員未與任何對等方連接,因此確定鏈上存在的唯一方法是詢問以太坊節點。
Untrust在其鏡像網絡上進行了一次虛構的交易,該網站運營的MoneyMover協調員將其檢測為有效付款。Untrust現在無需付費即可訪問該網站。網站只會在他們提交交易或切換到其他以太坊供應商時才發現這種虛構的付款。
動態 | 2月Github開發活動活躍的20個項目中 有16個建立在以太坊區塊鏈上:據Consensys統計,2月份Github開發活動活躍的20個項目中,有16個建立在以太坊區塊鏈上,2個是區塊鏈互操作性網絡,1個構建于Steem上,還有1個試圖構建于EOS上。[2019/3/5]
實際可能出現的風險
以上的攻擊是僅當協調員未運行其自己的以太坊節點時,此攻擊才有意義。有一些情況是有問題的:
1.協調員數據的下游使用者無法知道他們接收的數據是否存在,他們不能信任協調員正在使用的eth節點,因為使用者沒有自己運行該節點。
2.欺詐證明者尤其容易受到這種攻擊,因為它們僅在檢測到欺詐行為時才會提交交易。惡意的eth節點可能會從區塊鏈數據中剝離無效交易,并僅返回不同的狀態哈希。欺詐證明者將無法得知狀態哈希是虛構的,并且永遠不會提交欺詐聲明。
3.eth節點操作員向Rollup協調員說謊,以誘使他們要么提交無效的狀態交易,要么提交無效的欺詐聲明。一旦發生這種情況,惡意的eth節點運營商就可以充當有效的交易對手并收集抵押的資金。
現場 | 以太坊核心研究員Karl Floersch: PoS共識機制帶來的機遇和挑戰:金色財經9月8日現場報道,在香港召開的以太坊行業峰會(ETHIS)上,Karl Floersch介紹了以太坊過去幾年的進展以及數字貨幣經濟是如何一步一步推進的。從技術角度開始,通過社交網絡模型講解信息傳遞和同步的概念,引出運用時間戳概念和PoS共識機制將有效解決作惡節點的雙花問題。[2018/9/8]
解決方案1
在工作量證明鏈的背景下,協調員可以請求塊數據并檢查其是否足夠困難。檢查當前難度的至少一半應該可以使大多數攻擊因為財務問題無法實現。
在權益證明鏈中,這個過程變得不可行,因為惡意的eth節點可能會從未投票的地址提供簽名。他們可以通過在查詢時質押抵押金額來做到這一點。
解決方案2
一個不太優雅的解決方案是:對信譽良好的節點不斷簽名,并發布已存在于鏈上的Rollup狀態哈希的列表。該列表可以在IPFS之類的服務上發布。協調員節點可以包括一個已知的信譽良好的公共密鑰的預設列表。
如果出現以下情況,協調員會知道Rollup數據是真實的:
1.所有狀態交易均有效。
2.所有狀態散列均由信譽良好的來源進行簽名。
這將確保Rollup數據有效且非虛構,并且將允許Rollup節點使用任何以太坊節點來同步數據。
以上是「jchancehud」討論的Rollup安全攻擊的可能性。
主要是因為Rollup是鏈下狀態,容易在很多狀態里出現信息同步不及時的情況,據「jchancehud」表示的,需要驗證鏈下狀態是否有效的一方需要同步其他以太坊全節點的數據才可以確認最終安全性,這意味著很多平臺需要運行一個以太坊節點。
對于上文舉出的虛擬攻擊方式,以太坊的layer2解決方案團隊SKALELabs首席技術官「KonstantinKladko」表示,“這真的很有趣!我認為這表明,通過破壞Infrua,可以基本上破壞所有Rollup。”
當然,這是代表著那些通過Infura來與以太坊通訊的產品,Infura承擔著很大的以太坊節點服務規模,此前也有關于Infura是否會是以太坊網絡最大單點漏洞的討論。而對于這個單點安全風險,主要是以多節點負載均衡的方式處理,盡力規避。
而對于「jchancehud」的討論,最有趣的是開發者「adlerjohn」提出,這種虛擬的“攻擊”似乎不僅適用于optimisticRollup,而且還適用于zkRollup,實際上也適用于任何智能合約。
這一推論很可能是基于“只要存在信息不對稱危險”的協作過程,就會面臨「jchancehud」所說的攻擊風險。
所以「adlerjohn」提出,在比特幣的白皮書第8節,有如何驗證信息對錯的方式,即驗證者確定最長鏈,信任最長鏈,這個方式描述了一種眾所周知的方案,這個該方案可用于防止Sybil節點提供虛假信息,這樣可以不要求大多數計算是誠實的。
比特幣白皮書的第8節
此外,「adlerjohn」提出,Rollup的狀態根可以作為事件發出,甚至可以存儲在以太坊狀態中,也可以進行偽造交易的查詢。
比特幣白皮書的第8節
另外,「adlerjohn」還提到了關于optimisticRollup方案中,還可以包含名為“最小可行合并共識”的設計,該設計可以通過發布有序數據來實現數據可用性,可以讓多個側鏈、分片使用。
白計劃注:最小可行合并共識的解讀在如下鏈接
https://ethresear.ch/t/minimal-viable-merged-consensus/5617
但可以預見的是,使用「adlerjohn」提出的方式,是存在較大的設計難度的。
在討論的最后,「jchancehud」回復「adlerjohn」表示,不能確定這種攻擊預測是否適用于ZKRollup。但因為ZK證明更難生成,至少會更加困難。如果Rollup被廣泛采用,那么這樣考慮Rollup尤其重要。
Rollup協調員可以在使用節點之前驗證節點中的所有區塊頭,這是另一種潛在的解決方案,盡管時間和帶寬昂貴。但用戶最好運行自己知道可以信任的eth輕節點。如果已經解決驗證問題,運行輕節點還可以查詢事件。
討論在最后,我們會發現為了實現安全性、可擴展性、效率,這些方案按工程化的思路是可以嘗試的,但實施過程一定是困難的,因為不同開發者的討論思路最后還要合成代碼,以及包含網絡結構、客戶端、語言、操作界面等多個挑戰。
時間戳向前,區塊不停,我們繼續期待吧。
敬的用戶: HuobiGlobal“全球觀察區”定于2021年1月22日上線REFF(ReefFinance)。每個母、子賬戶的REEF最大持倉量均為50000USDT等值代幣.
1900/1/1 0:00:00非必要不前往中高風險地區,非必要不出境。各級黨政機關、事業單位、國有企業、在甬高校要嚴格落實請示報告制度,嚴格管理在編在職人員休假出行活動,春節期間取消非公務出境活動,減少不必要的省外出行,未經.
1900/1/1 0:00:00微軟和印度的云通信公司TanlaPlatforms已經推出了基于區塊鏈的通信平臺即服務,旨在提供更多的私有和安全消息傳遞.
1900/1/1 0:00:00建議廣大民眾非必要不離粵,非必要不到中高風險地區,非必要不到境外,如必須出行,要合理安排行程。倡導非必要不出行、暫緩前往中高風險地區Ripple:UBRI目前已在六大洲建立了50多所大學合作伙伴.
1900/1/1 0:00:00上一篇文章《NFT到底怎么玩?為什么CROSS備受矚目?》跟大家詳細介紹了NFT,本文將以CROSS為主角再次跟大家深入討論下NFT.
1900/1/1 0:00:001.廊坊市固安縣繼續實施封閉管理至1月25日,除固安縣外的其他地區,繼續實施封閉管理至1月18日。與市外相通的路口進行24小時嚴密查控人員、車輛非必要一律不得流出.
1900/1/1 0:00:00