上一講中,我們簡單提到了什么是分片。今天的文章我們會詳細介紹以太坊的分片技術。
什么是分片?
分片是數據庫系統中抽離而來的一個詞。我們先來介紹下數據庫中分片的概念。假設你的網站上有大量的數據庫存儲,這不僅會導致數據搜索速度減慢,還會影響可擴展性。這種情況下我們可以做些什么呢?
能不能把數據橫向切分成小的數據表格,并把他們存儲在不同的數據庫服務器中?
你或許會問為什么要進行橫向切分而不是垂直切分呢?這是由于數據表格本身的設計導致的。
我們現在進行垂直切分。
注意到了嗎?垂直切分后會把整個數據庫表切割成兩個完全不相干的數據表格。
但是橫向切分的話,還是同一個由A,B,AB,A-B構成的數據庫,只不過每個數據庫中的數據存量減少了。這些小的數據庫就是大的數據庫的分片。每一個分片的表格結構都相同。
Aave即將開啟“使用金庫200萬枚aUSDT購買500萬枚aCRV”提案投票:8月8日消息,Aave關于使用金庫中200萬枚aUSDT購買500萬枚aCRV的提案將在11小時后開始投票。提案表示,這一舉措能夠發出支持DeFi的強烈信號,并能用于在Curve戰爭中獲取戰略地位,提升GHO流動性。[2023/8/8 21:31:29]
區塊鏈中的分片
上一講中,我們提到過以太坊共識的問題在于所有的節點都必須對同一筆交易進行計算和確認。整個計算過程又慢又繁瑣。分片技術可以如何改善這個問題呢?
現在我們來設想一下:整個以太坊區塊鏈就是一個“萬國領土”,可以分割給所有人。這個萬國領土的默克爾樹根會切分成大大小小不同的分片根,每一個分片根都擁有自己的國度。讓我們以默克爾樹的形式把這些國度表現出來:
Binance Labs向幣安轉入450萬枚LOKA:4月19日消息,據推特用戶余燼監測,Binance Labs 地址于昨日向幣安轉入 450 萬枚 LOKA(價值約 271 萬美元)。余燼表示,Binance Labs 投資獲得 LOKA 數量為 600 萬,目前已解鎖 450 萬,還有兩期共計 150 萬 LOKA 尚未解鎖。[2023/4/19 14:14:19]
這就是整個萬國領土切分成多個小國的簡單結構圖。現在讓我們來看一下內部機制。
分片啟動后會發生什么呢?
*萬國領土被分割成多個分片*每一個獨特的賬戶都代表著一個分片*只有同一個分片里的賬戶能相互轉賬。
在以太坊的開發者大會中,Vitalik是這樣解釋分片的:
假設以太坊被分割成成千上萬個小的島嶼。每個島嶼都是自治的。每個島嶼都有自己的特色,島嶼上的每個人都可以跟其他島民互動,并且隨意享用這個島嶼的特色。如果你想跟其他島嶼互動,就必須使用某種特定的協議。
美國財務會計準則委員會發布關于加密資產會計和披露的擬議會計準則更新:4月3日消息,美國財務會計準則委員會(FASB)關于加密資產會計和披露的擬議會計準則更新,提議更像對待傳統資產那樣對待加密資產,并將提高估值的準確性。
目前,公認會計原則(GAAP)要求公司在資產負債表上將持有的加密貨幣視為“無限期無形資產”。根據現行公認會計原則,加密資產每年都會進行減值測試。[2023/4/4 13:42:48]
那么問題來了,這種分片技術對區塊鏈有什么影響呢?我們先來看一下比特幣和以太坊中一個正常的區塊長什么樣子?
一個區塊中由區塊頭和包含所有交易的區塊主體構成。所有交易的默克爾根都存在在區塊頭中。
現在讓我們來自問一下:比特幣真的需要區塊嗎?真的需要區塊鏈嗎?中本聰本可以把上一筆交易的哈希記錄在一筆新的交易之中,用這種簡單的方式就可以構成一條交易鏈。
Sui宣布Builder House越南站獲勝團隊:3月20日消息,Layer1公鏈Sui Network宣布Builder House越南站獲勝團隊,多鏈NFT市場Mynft團隊獲得第一名,收益協議Typus Finance團隊獲得第二名,隨機利率協議Scallop和SocialFi應用程序ComingChat團隊獲得第三名。據悉,SuiBuilder Houses提供與全球Sui構建者會面和合作的機會。2023年Sui計劃在12個地方舉行Builder Houses,越南站是第二站,下一站將于4月14日至4月16日在香港舉辦。[2023/3/20 13:14:04]
把交易都記錄在區塊中的目的是為了創造一層交互,讓整個過程更加可擴展。以太坊想做的是實現兩層交互。
第一層
第一層是交易組。每一個分片都有自己的交易群。交易群包括交易群頭和交易群主體。
Sui發布SUI代幣分配細節,基金會管理的社區儲備占50%:12月15日消息,Sui基金會發布SUI代幣經濟學分配細節,其中基金會管理的社區儲備占50%,早期貢獻者占20%,投資者占14%,Mysten實驗室金庫占10%,社區訪問計劃和應用測試人員占6%,并表示Sui基金會將把向Sui早期社區成員獎勵和分發SUI代幣作為重中之重。
此前報道,5月份Sui公布代幣經濟學模型,總量100億枚,有四個用途:被抵押以參與權益證明機制(PoS)、支付Gas費以執行交易和其他操作、支撐整個Sui經濟的多功能和流動資產、參與鏈上投票來發揮重要的治理作用。[2022/12/15 21:46:01]
交易群頭包括左右兩個部分。左側包含的信息如下:
*分片ID:交易組所屬的分片ID*前狀態根:這是交易執行前分片43的根狀態。*后狀態根:交易執行后分片43的根狀態。
右側信息如下:
*右側是隨機選取的需要在分片內確認交易的確認者。*交易組主體*包含了分片中所有交易的ID。
第一層的特征
*每一筆交易對應著它所屬分片的ID。*某特定分片中的一筆交易表明這筆交易的發起和接收賬戶都在這個特定的分片中。*交易群組中的交易只存在于分片ID之中,具有特定的前后狀態根。
現在我們來看一下第二層交互
別跑!其實非常簡單。
這就是一般的區塊鏈結構,只不過現在包括兩個主要的根:
*狀態根(stateroot)*交易群根
狀態根代表了整個以太系統的根。我們之前提到過,這個系統被切分成大大小小的分片,對應著它們各自的分國度。
交易群根包含了某特定區塊里所有的交易群。
第二層的特征
第二層是一個簡單的區塊鏈,記錄交易群而不是交易本身。交易群合法的唯一條件是:
*前狀態根與整個系統的分片根相符。*交易群組中的所有簽名都已經得到了確認。
交易群進入區塊后,整個系統的根就變成了特定分片ID的后狀態根。
那么跨分片通信是怎么實現的呢?還記得之前的島嶼比喻嗎?
分片就相當于島嶼。它們如何互相聯系呢?記住,分片的目的是讓很多平行交易同時發生來提高性能。如果以太坊允許任意的跨分片交流,那么整個分片就毫無意義了。
因此以太坊協議要如何設計來允許跨分片通信呢?以太坊使用收據實現跨分片通信。
如你所見,每筆交易的收據只需通過這個交易群的多個默克爾根就可以輕松訪問。分片中的每一筆交易都會做兩件事情:
*改變所屬分片的狀態*產生收據
數據存儲在分布式共享內存中,其他分片可以看到,但是無法修改。通過數據跨分片交流如下:
實行分片技術的挑戰有哪些?
*我們需要一種機制來知道每個節點執行了哪個分片,這種機制還要能保證系統安全又高效。*根據以太坊研究員VladZamfir的說法,在實現分片之前需要以太坊需要先轉到POS算法。節點之間可以互不信任,但是也需要能夠達成共識。如果某筆交易分割成多個分片,并分配給節點A和節點B,節點A和B需要利用某種機制來證明自己完成了分片中各自對應的工作量。
總結
隨著以太坊的進一步崛起,大都會和寧靜階段的到來,分片對以太坊越來越重要。如果以太坊想要演化成新一代的互聯網,必須要解決可拓展性問題。采用分片后的以太坊會如何發展,讓我們拭目以待。
來源鏈接:None
免責聲明:作為區塊鏈信息平臺,本站所發布文章僅代表作者個人觀點,與鏈聞ChainNews立場無關。文章內的信息、意見等均僅供參考,并非作為或被視為實際投資建議。
本文來源于非小號媒體平臺:
行走的翻譯C
現已在非小號資訊平臺發布19篇作品,
非小號開放平臺歡迎幣圈作者入駐
入駐指南:
/apply_guide/
本文網址:
/news/9602874.html
免責聲明:
1.資訊內容不構成投資建議,投資者應獨立決策并自行承擔風險
2.本文版權歸屬原作所有,僅代表作者本人觀點,不代表非小號的觀點或立場
上一篇:
幣安為何推出第三條鏈?這對BNB意味著什么?
嚴格管理人員省外出行,如確需前往的,必須報本單位主要領導批準。國家公職人員要做好表率,持續關注國內外疫情風險動態,合理安排出行,減少不必要外出。無特殊情況不要出境,不要前往中高風險地區.
1900/1/1 0:00:00本報告由中國工業與應用數學學會區塊鏈專委會、中國通信工業協會區塊鏈專委會、中國移動通信聯合會區塊鏈專委會、湖南省東方區塊鏈安全技術檢測中心、湖南大學數字社會和區塊鏈研究院、湖南省天河區塊鏈研究院.
1900/1/1 0:00:00尊敬的用戶: 為了給您提供更便捷、更專業的財富管理服務,HuobiGlobal財富管理版塊即將全面升級,升級后現有”存幣寶”業務將與新產品“挖礦寶”業務合并,新產品挖礦寶同樣支持活期申購功能.
1900/1/1 0:00:00非必要不離盟、不返鄉 春節農村返鄉人員需持7天內有效新冠病核酸檢測陰性結果,返鄉后實行14天居家健康監測,期間不聚集、不流動,每7天開展一次核酸檢測.
1900/1/1 0:00:00?在這個多空難測的市場上,有人能賺到錢,但也有很多朋友做的不夠理想。在該做空的時候,怕沖高。該做多的時候,怕回落。其實這就是人心,而人心就是最復雜的技術.
1900/1/1 0:00:00?Compound總法律顧問JakeChervinsky認為,流行的借貸協議更像是利率協議,不是真正的借貸協議。他認為DeFi中沒有真正的借貸協議.
1900/1/1 0:00:00