你或許也知道,限制目前區塊鏈技術大規模落地應用的一個很重要因素就是性能,這也是為什麼很多傳統互聯網從業者不太看好區塊鏈技術的一個原因。
那麼,如何解決區塊鏈的性能問題呢?其中的一個解決方案就是分片技術(Sharding)。
什麼是分片?
分片是數據庫分區的一種形式,也稱為水平分區,即將一個大的數據庫切分成很多小的、可處理的部分,從而提高性能,縮短響應時間。
分片並不是一個新的概念,早在90 年代後期就出現在了傳統的中心化數據庫管理中。這個概念的流行,要歸功於一個多玩家同時在線玩的角色扮演遊戲Ultima Online。
在這個遊戲中,開發者將玩家分配到不同的服務器來緩解流量壓力(這意味著有很多個平行的“遊戲世界”)。商業上,一個普遍的分片案例就是將用戶信息的數據庫按照地理位置劃分,同一個區域的用戶信息放在一起,存到單獨的服務器中。
什麼是區塊鏈領域裡的分片?
區塊鏈就相當於一個數據庫,每一個節點都相當於一個獨立的服務器。正常情況下,這些節點每次只有一個節點能獲得記賬出塊的權利,剩下沒獲得出塊權的節點相當於做了“無用功”,白白浪費了算力。
如果將分片技術運用到區塊鏈中,就相當於將區塊鍊網絡裡的所有待處理任務(比如確認交易、運行DApp 等)進行分解,全網的節點也進行分組,每一組同時處理一個分解後的任務(比如150 筆待確認交易),這樣就從原先單一節點處理全網的所有任務變成了多組節點同時並行處理。
舉個例子,假設目前以太坊上有8,000 個節點(礦工),全網待確認的交易是15,000 筆。以太坊每秒能處理7-15 筆交易,正常情況下至少需要1000 秒才能處理完這些待確認的交易,當然處理的過程中又會有新的待確認交易產生。
如果採用分片技術,將8,000 個節點分成100 組,每組80 個節點,這15,000 筆待確認交易分成100 個分區,每個分區150 筆,那麼,每組節點(80 個)可以並行處理各自分區裡的待確認交易(150 筆),這樣最快10 秒鐘就可以全部處理完那15,000 筆待確認交易。
從這個例子中,我們可以看到,分片技術可以大幅提高區塊鏈的性能。
分片技術潛在的風險
那麼,分片技術有沒有缺陷呢?答案是肯定的。
分片技術雖然能在一定程度上解決區塊鏈的性能問題,讓區塊鏈更具有可擴展性,但也存在兩個缺陷。
一個是分區後,不同區的通信問題。上面的例子,將以太坊網絡分成100 個分區,每個分區都是獨立的,相當於有100 條獨立的、平行的以太坊區塊鏈,每條都由一組礦工(80 個節點)維護和確認交易。
這100 條獨立的以太坊區塊鏈並不能相互通信,如果要通信,勢必要增加跨分區的通信機制(類似垮鏈),這會增加區塊鏈的複雜性,開發難度也會提高。
第二個是區塊鏈的安全性。還是上面的例子,在未分片之前,以太坊網絡是8,000 個節點組成的算力,分成100 個分區後,每個分區相當於一條獨立的以太坊區塊鏈,算力下降到80 個節點組成的算力。
此時,對其中一個分區進行51% 算力攻擊就容易很多。控制了一個分區,攻擊者就可以在這個分區內做惡,篡改交易。
以太坊基金會計劃將分片技術作為以太坊2.0 的升級內容之一。以太坊如何解決分片技術的上述2 個缺陷,我們拭目以待。
除了性能問題,你覺得目前的區塊鏈技術還存在哪些問題?歡迎在留言區分享。