本文來自:
Defi之道
,作者:
以太坊創始人
Vitalik
Buterin
,星球日報經授權轉發。
區塊鏈的可擴展性究竟能達到什么程度?真能如ElonMusk所愿“通過將區塊時間縮短10倍,將區塊大小增加10倍從而將手續費降低100倍”,而又不會導致極端中心化并損害區塊鏈本質的基本屬性嗎?如果不能,那區塊鏈的可擴展性究竟能達到什么程度?如果選擇通過更改共識算法來進行擴展,又會怎么樣?更重要的是,如果您更改技術以引入諸如ZK-SNARK或分片之類的功能,會怎么樣?從理論上講,分片的區塊鏈可以持續添加更多的分片,這會不會導致添加的東西更多?
事實證明,有一些重要且相當微妙的技術因素限制了區塊鏈的擴展性,即便是采用分片的區塊鏈也面臨這些問題。在許多情況下,我們都會有相應的擴展性解決方案,但是這些解決方案也存在局限性。這篇文章將探討這些可擴展性方案中存在的許多問題。
只需增加參數即可解決所有問題。但代價是什么?
1普通用戶也
能運行節點,這對于區塊鏈去中心化至關重要
凌晨2:35,您收到來自世界另一端的伙伴的緊急電話,他在幫助您管理礦池。您的伙伴告訴您,從大約14分鐘前開始,您的池子和其他幾個池子突然從鏈上分裂出來,原始鏈仍舊承載著79%的網絡算力。根據您的節點,這個多數鏈生產的區塊是無效的。這出現了余額錯誤:密鑰區塊似乎錯誤地將450萬枚額外代幣分配給了一個未知地址。
一個小時后,您開始與其他兩個像您一樣迷茫的礦池以及一些區塊瀏覽器和
交易所
在電報群中溝通。最后你看到某人發出了一個推特鏈接。該推文寫道:“新的鏈上可持續協議發展基金正式發布”。
到了早上,推特上、社區論壇上開始充滿沒有審查過的論點,各種討論無處不在。但是這時候,此前新增發的450萬枚代幣中的很大一部分已經在鏈上被轉換為其他資產,進而已經進行了數十億美元的
DeFi
V神:被動信任和維護主動服務信任是完全不同兩件事:今日早些時間,以太坊域名服務(ENS)核心開發者Nick Johnson發文表示,已經在ENS會議上演示的Layer 2網關解決方案。以太坊創始人V神評論稱:首先,如果我們信任合約,我們也應該信任它來指定一個可以回答我們查詢的網關URL。就我個人而言,這似乎非常可怕。被動信任和維護主動服務的信任是完全不同的兩件事。特別是對于Merkle-drop用例,構建一個dapp而不是應用程序半數用戶體驗的好處是“隨發隨棄”的能力,并且不必維護在線服務器。但我絕對想把用戶直接鏈接到解決方案上。我想我會采取的方法不是鏈接到URL,而是鏈接到P2P子網ID或開放訪問鏈上的URL注冊表,并讓用戶從任何可用的證明者中選擇。[2020/10/30 11:15:10]
交易。79%的共識節點以及所有重要瀏覽器和輕
錢包
都正在遵循這一新鏈條。也許這個新的
開發者
基金將為某些開發提供資金,或者也許所有這些資金都會被領先的礦池,交易所等吞掉。但是,不管結果如何,該基金在所有意圖和目的上都是既成事實,而普通用戶則無力反擊。
好戲即將上映。也許可以由MolochDAO或其他機構資助。
這種事情能發生在您的區塊鏈上嗎?您的區塊鏈社區的精英,包括礦池,區塊瀏覽器和托管節點,可能協調得很好。他們很可能都在同一個電報群和微信群中。如果他們真的想對協議規則進行突然更改以促進自己的利益,那么他們可能會這樣做。以太坊區塊鏈曾在十小時內完全解決了一個共識失敗;如果您的區塊鏈只有一個客戶端實現,并且您只需要將代碼更改部署到幾十個節點,那么協調更改客戶端代碼的速度就可以更快。使這種協調的社會攻擊無效的唯一可靠方法是通過去中心化社區的積極防御,也就是用戶。
想象一下,如果用戶正在運行驗證區塊鏈的節點,并自動拒絕破壞協議規則的區塊,即使超過90%的礦工或質押者支持該協議,結局會怎么樣。如果每個用戶都運行一個驗證節點,那么這種攻擊將很快失敗:一些礦池和交易所將
分叉
,但這看起來很愚蠢。但是,即使只是某些用戶運行了驗證節點,該攻擊也不會為攻擊者帶來勝利。相反,這將導致混亂,因為不同的用戶會看到不同的鏈。至少,隨之而來的市場恐慌和可能持續的鏈分裂將大大降低攻擊者能夠獲得的利潤。要解決沖突所需要的大量時間成本本身就會讓攻擊者放棄攻擊想法。
V神:單數據根需要高帶寬P2P網絡及更復雜的P2P基礎設施:針對此前V神稱希望可以擺脫委員會,推特網友Mustafa Al-Bassam持續與V神進行互動。該網友表示:“建議仍然有一個委員會,但只有1個委員會而不是64個委員會。這允許區塊生產者在其自己的節點內分片生產區塊。大礦池將分配給所有分片。至于完全消除委員會(即直接使用Nakamoto共識),我對依靠單個數據根的抽樣感到非常滿意。如果有多個數據根,那么我感到不舒服。輕客戶端假設的數量是零散的。不過,在無委員會的多數據根模型中,一個重要的考慮是,客戶端更可能意外地接受64個不可用數據根中的1個為可用,而不是1個不可用數據根中的1個為可用。”V神則表示:“單數據根的挑戰在于,你需要一個非常高帶寬的P2P網絡,沒有多少節點能夠直接連接到它,所以你需要更復雜的P2P基礎設施,以使常規客戶能夠查詢。如果有多個數據根,那么我感到不舒服。輕客戶端假設的數量是零散的。我不認為這是真的,因為不是每個客戶都選擇64個分片中的一個來檢查,而是每個客戶都需要檢查每個分片。因此,問題不在于安全方向,而在于效率方向。”[2020/10/5]
讓我們搞清楚一點:你對惡意協議更改的抵抗來自于一種由用戶驗證區塊鏈的文化。而不是
PoW
或
PoS
——Hasu
這一點可以看Hasu怎么說的
如果您的社區由37個節點運行者和80000個被動聽眾組成,他們負責用于檢查簽名和區塊頭,那么攻擊者將獲勝。如果您的社區的每個人都在運行節點,那么攻擊者將會失敗。我們不知道針對協同攻擊的“牛群免疫”的確切閾值是多少,但是有一件事情是絕對清楚的:節點越多越好,節點越少越糟糕,我們肯定需要不止幾十個或幾百個。
2
那么,我們需要全節點完成多少工作?
為了最大化可以運行節點的用戶數量,我們將重點關注常規的消費級硬件。可以通過要求一些容易購買的專用硬件來增加一些網絡容量,但是實際上這并沒有給擴展性帶來太多增加。
全節點處理大量交易的能力存在三個關鍵限制:
V神:糟糕的技術+良好的營銷有可能成功,但只會讓世界變得更糟:V神發推稱:“優秀的技術加上糟糕的營銷也可能會失敗,這是一個悲劇。糟糕的技術加上良好的營銷確實有可能會成功,但要知道,通過制造劣質產品取勝,可能會讓世界變得更糟。優秀的技術結合良好的營銷才是最理想的。”[2020/4/16]
計算能力:在
安全
運行一個節點的情況下,需要占用多少百分比的CPU能力?
帶寬:考慮到當前互聯網連接的現實情況,一個區塊可以包含多少個字節?
存儲:我們可以要求用戶存儲多少GB磁盤?另外,讀取速度要求多快?
許多對使用“簡單”技術可將區塊鏈擴展到多遠的錯誤觀點,是由于對這些數字中的每個都過于樂觀。我們可以一一介紹一遍這三個因素:
計算能力
錯誤:100%的CPU能力可以用于區塊驗證
正確:大約5-10%的CPU能力可用于區塊驗證
百分比如此低主要原因有四個:
我們需要一個安全邊際來應對DoS攻擊的可能性
節點離線后需要能夠同步鏈。如果我斷開網絡一分鐘,我應該能夠在幾秒鐘內再次與網絡同步
運行節點不應太快耗盡電池電量,也不應使所有其他應用程序的運行變慢
節點還需要執行其他非區塊生產任務,主要圍繞在p2p網絡上驗證和響應傳入的交易和請求。
請注意,直到最近,大多數針對“為什么只有5-10%?”的解釋專注于一個不同的問題:由于PoW區塊是隨機出現的,因此驗證區塊所花費的時間較長,會增加同時創建多個區塊的風險。有許多解決此問題的方法。但是這些修補程序不能解決其他四個問題,因此它們無法像許多人最初認為的那樣在擴展性方面帶來巨大的好處。
并行性也不是萬能的。通常,即使是看似單線程的區塊鏈客戶端也已經并行化:簽名可以由一個線程驗證,而執行則由其他線程完成,并且有一個單獨的線程在后臺處理交易池邏輯。而且,越接近所有線程100%的使用率,運行節點所消耗的能量就越多,并且抵御DoS的安全邊際也越低。
聲音 | V神:我希望以太坊的登錄可以標準化:今日有DApp開發者發推表示:“讓用戶選擇通過MetaMask,WalletConnect,Portis,Bitski,Formatic,Ledger或Trezor連接到DApp,這是糟糕的用戶體驗。更多選擇并不等于更好的體驗,選擇一個并圍繞它構建整個體驗。\"V神回復:“我希望以太坊的登錄可以標準化,而不是“使用元掩碼登錄”(或分類帳和端口等登錄方式)。為什么DApp用戶界面顯示所有這些選項,而不是錢包提供通用標準界面,這樣DApp用戶界面就能檢測用戶擁有的內容。”[2019/7/26]
帶寬
錯誤:如果我們每2-3秒就有產出10MB大小的數據區塊,那么大多數用戶的網絡速度都>10MB\u002F秒,因此他們當然可以處理這樣的區塊
正確:也許我們可以每12秒處理1-5MB的區塊。這已經很難了。
如今,我們經常聽到關于互聯網連接可以提供多少帶寬的廣告統計數據:通常聽到100Mbps甚至1Gbps的數字。但是,由于以下幾個原因,廣告中的帶寬和預期的實際帶寬之間存在很大差異:
“Mbps”是指“每秒數百萬個比特”;比特是字節的1\u002F8,因此您需要將廣告的比特數字除以8以獲得廣告中的字節數。
就像所有公司一樣,互聯網提供商經常說謊。
總是有多個應用程序使用同一互聯網連接,因此節點無法占用整個帶寬。
p2p網絡不可避免地會帶來其自身的開銷:節點經常最終會多次下載并重新上載同一區塊。
Starkware在2019年進行了一次實驗,他們首次發布了500kB的區塊,這是因為交易數據gas成本的降低首次使這種可能性成為可能,但實際上有幾個節點無法處理該大小的區塊。此后,處理大區塊的能力得到了改善,并將繼續得到改善。但是,無論我們做什么,我們仍然無法天真地獲取以MB\u002F秒為單位的平均帶寬,讓自己相信我們可以接受1s的延遲,并且能夠擁有如此大小的區塊。
存儲
錯誤:10TB
正確:512GB
V神發推特:特殊情況下硬分叉“挽救”行為對新生區塊鏈是個不錯的選擇:以太坊創始人Vitalik Buterin 剛剛發布推特回應稱,在特殊情況下的硬分叉“挽救”行為對于早期的新生區塊鏈來說是個不錯的選擇。近日,有評論稱以太坊樹立了一個壞榜樣,現在每次有黑客事件發聲,就會有人要求硬分叉追回。[2018/2/11]
您可能會猜到,這里的主要論點:理論與實踐之間的差異。
從理論上講,您可以在亞馬遜上購買8TB固態硬盤。實際上,用于撰寫此博客文章的筆記本電腦具有512GB存儲空間,并且如果您讓人們去購買自己的硬件,則其中許多都只會變得很懶惰,并且使用中心化提供商。即使您可以將區塊鏈安裝到某個存儲上,高水平的活動也可以輕松地快速刻錄到磁盤上,并迫使您不斷購買新磁盤。
一組區塊鏈協議研究人員對每個人都有多少磁盤空間進行了調查。我知道樣本量很小,但仍然可以說明一些問題。
此外,存儲大小決定了新節點能夠聯機并開始參與網絡所需的時間。現有節點必須存儲的任何數據都是新節點必須下載的數據。初始同步時間也是用戶運行節點的主要障礙。在撰寫此博客文章時,同步新的geth節點花了我大約15個小時。
如果以太坊的使用量增加了10倍,那么同步一個新的geth節點將至少花費一周的時間,這很可能導致您的網絡連接受到限制。在攻擊過程中,當對攻擊的成功響應涉及到從未運行過節點的新用戶時,這尤其重要。
3交互效應
此外,這三種成本之間存在交互作用。由于數據庫內部使用樹結構來存儲和檢索數據,因此從數據庫中獲取數據的成本隨數據庫大小的對數增加而增加。實際上,因為可以將頂層緩存在RAM中,所以磁盤訪問成本與數據庫的大小成正比,是緩存在RAM中的數據大小的倍數。
4p4mprfy1!webp\"data-img-size-val=\"582,121\"\u002F\\>
不要從字面上看這張圖。不同的數據庫以不同的方式工作,并且內存中的部分通常只是一個單層。但是基本原理是相同的。
例如,如果緩存為4GB,并且我們假設數據庫的每一層都比前一層大4倍,則以太坊當前的?64GB狀態將需要約2次訪問。但是,如果狀態大小增加4倍至?256GB,那么這將增加至?3次訪問。因此,gas限制增加4倍實際上可以轉化為區塊驗證時間增加約6倍。效果可能更強:硬盤已滿時,讀取和寫入所需的時間通常比硬盤快用完時要更長。
4那么這對以太坊意味著什么呢?
如今,在以太坊區塊鏈中,盡管在常規硬件上仍然可行,但運行一個節點已經對許多用戶構成挑戰。因此,我們正在接近瓶頸。核心開發人員最關心的問題是存儲大小。因此,目前,在解決計算和數據瓶頸方面的英勇努力,甚至是對共識算法的更改,都不太可能導致人們接受的gas限制大幅度增加。即使解決了以太坊最大的突出DoS漏洞,也只能使gas限制增加20%。
解決存儲大小問題的唯一方法是無狀態和狀態到期。無狀態允許一類節點在不維護永久性存儲的情況下驗證區塊鏈。狀態到期會釋放出最近未訪問的狀態,需要用戶手動提供繼續維護這些狀態的證據。這兩種路徑都已經使用了很長的時間,并且關于無狀態的概念驗證實現也已經開始。這兩項改進相結合,可以極大地緩解這些擔憂,并為大幅提高gas限制打開空間。但是,即使在實施了無狀態和狀態到期之后,gas限制可能也只能安全地增加大約3倍,然后其他局限性再次開始主導。
5分片之后會發生什么?
分片從根本上克服了上述限制,因為它使區塊鏈中包含的數據與單個節點需要處理和存儲的數據脫鉤,而不是節點通過親自下載和執行來驗證區塊,而是使用先進的數學和密碼技術來間接驗證區塊。
結果就是,采用分片的區塊鏈可以安全地擁有非分片區塊鏈無法做到的非常高的交易吞吐量。這確實需要很多密碼學上的聰明才智來創建能成功地拒絕無效區塊的完全驗證的有效替代品,但是可以做到這一點:該理論已經建立并且基于規范草案的概念驗證已經在研究之中。
以太坊正計劃使用二次分片,其總體可擴展性受到以下事實的限制:節點必須能夠處理單個分片和信標鏈,而信標鏈必須對每個分片執行一定的管理工作。如果分片太大,則節點將無法再處理單個分片;如果分片太多,則節點將無法再處理信標鏈。這兩個約束的乘積就形成了一種上限。
可以想象,可以通過三次分片甚至指數分片來走得更遠。在這種設計中,數據可用性采樣肯定會變得更加復雜,但可以做到。但是以太坊不會采用比二次分片更高的分片了。原因是,從交易的分片的分片實際上無法實現額外的擴展性增益,除非其他風險開始變得不可接受地高。
6
那么這些風險是什么?
最小用戶數
可以想象,即使只有一個用戶愿意參與其中,非分片的的區塊鏈也可以運行。而分片區塊鏈不是這樣的:沒有單個節點可以處理整條鏈,因此您需要足夠的節點,以便它們至少可以一起處理區塊鏈。如果每個節點可以處理50TPS,而整條鏈可以處理10000TPS,則該鏈至少需要200個節點才能生存。如果該鏈在某個時候少于200個節點,則要么節點無法再跟上鏈,要么節點停止檢測無效塊,否則可能會發生其他不良情況,具體取決于節點軟件如何設置的。
實際上,由于需要冗余,因此安全的最小節點數量比單純的“鏈TPS除以節點TPS”高出幾倍;對于上面的示例,我們說是1000個節點。
如果分片區塊鏈的容量增加10倍,則最小用戶數也將增加10倍。現在,您可能會問:為什么我們不從容量很小的時候開始開始,在看到大量用戶時增加容量,在用戶數量減少時減小容量?
這里面其實有一些問題:
區塊鏈本身無法可靠地檢測到有多少個唯一用戶,因此這將需要某種治理來檢測和設置分片數量。針對容量限制的管理很容易成為分裂和沖突的根源。
如果許多用戶突然并意外退出,該怎么辦?
增加啟動分叉所需的最小用戶數,使得惡意接管變得更加困難。
最低用戶數為1,000,這是幾乎肯定是可以的。另一方面,最低用戶數設為100萬,這肯定是不行。甚至將最低用戶數設為10,000,也是有點冒險的。因此,似乎很難證明擁有超過數百個分片的分片區塊鏈是合理的。
7歷史可檢索性
用戶真正珍視的區塊鏈的重要屬性是永久性。當公司破產或失去維護該生態系統的興趣時,存儲在服務器上的數字資產將在10年內停止存在。另一方面,以太坊上的
NFT
是永久的。
是的,到2372年,人們仍能夠下載和檢查您的加密貓。
但是一旦區塊鏈的容量過高,存儲所有這些數據就會變得更加困難,直到某個時刻存在很大的風險,歷史的某些部分最終將……沒人存儲。
量化這種風險很容易。以區塊鏈的數據容量為單位,乘以?30即可得到每年以TB為單位存儲的數據量。當前的分片計劃的數據容量約為1.3MB\u002F秒,因此約為40TB\u002F年。如果將其增加10倍,則將變為400TB\u002F年。如果我們希望數據不僅可以訪問,而且可以方便地訪問,那么我們還需要元數據,因此,這就是每年4PB,或者十年后達到40PB。互聯網檔案才使用50PB。因此,這是分片區塊鏈安全的合理體積上限。
因此,看起來在這兩個維度上,以太坊分片設計實際上已經大致針對相當合理的最大安全值。常數可以增加一點,但不能增加太多。
總結
嘗試擴展區塊鏈的方法有兩種:基本的技術改進和簡單地增加參數。首先,增加參數聽起來很有吸引力:如果您是在餐巾紙上進行數學運算,這就很容易讓自己相信家用筆記本電腦每秒可以處理數千筆交易,不需要ZK-SNARK,匯總或分片。不幸的是,有很多微妙的理由可以解釋為什么這種方法從根本上是有缺陷的。
運行區塊鏈節點的計算機無法花費100%的CPU能力來驗證區塊鏈;他們需要很大的安全邊際來抵抗意外的DoS攻擊,他們需要備用容量來執行諸如在內存池中處理交易之類的任務,并且您不希望在計算機上運行節點以使該計算機無法同時用于任何其他應用程序。帶寬同樣也有水分:10MB\u002Fs的連接并不意味著您每秒可以擁有10MB的區塊!也許是每12秒才能有1-5MB的塊。這與與存儲相同。增加對運行節點的硬件要求以及將節點的運行限制在專門的參與者上并不是一種解決方案。對于去中心化的區塊鏈而言,對于普通用戶而言,能夠運行節點并形成一種文化,即運行節點是一種普通活動,這一點至關重要。
另一方面,根本的技術改進是可行的。當前,以太坊的主要瓶頸是存儲大小,而無狀態性和狀態到期可以解決此問題,并允許將其增加最多約3倍——但不能更多,因為我們希望運行一個節點比現在更容易。
采用分片的區塊鏈可以進一步擴展,因為分片的區塊鏈中單個節點不需要處理每筆交易。但是即使是分片區塊鏈,容量也有局限性:隨著容量的增加,最小安全用戶數增加,歸檔區塊鏈的成本就會上升。
但是我們不必太擔心:這些限制足夠高,以至于我們可以在保證區塊鏈的完全安全性的同時每秒處理超過一百萬筆交易。但是在不犧牲使區塊鏈如此有價值的去中心化性質的前提下,還將需要做一些工作。
本文來自Defi之道,作者Glendon,星球日報經授權轉載。 今年3月,在一些最大的交易市場上,NFT藝術品交易量激增至2億美元以上,但4月的交易額卻下降了50%.
1900/1/1 0:00:002021年5月19日,比特幣市場經歷了自2020年3月黑色星期四以來最重大的流動性事件和價格回落.
1900/1/1 0:00:00SubstrateBuildersProgram是Parity發起的一項計劃,旨在支持Substrate生態系統中的建設者.
1900/1/1 0:00:00頭條 特斯拉暫停比特幣支付,正考慮使用能源消耗更低的加密貨幣特斯拉CEO埃隆·馬斯克發推稱,特斯拉暫停使用比特幣支付.
1900/1/1 0:00:00OpenChat是一款基于DFINITY互聯網計算機的去中心化聊天應用程序。通過OpenChat可以與好友發送文字、圖片或者其他附件進行交流,或者建立群聊進行多人聊天.
1900/1/1 0:00:00Odaily星球日報譯者|念銀思唐 摘要: -埃隆·馬斯克從2019年起就開始為Dogecoin開發人員提供咨詢。-由四位核心開發人員組成的團隊對他的建議表示歡迎,但拒絕了他提供的資金.
1900/1/1 0:00:00