近兩年,隨著以太坊等公鏈的生態發展,應用已經非常之多了,Defi、NFT這些應用雖然比較“簡易”,但鏈上整體操作量之大,讓用戶和開發者還是很相信以太坊的處理能力和其他公鏈的處理能力的。
不過,其他公鏈目前和以太坊相比,一個重要的優勢就是以太坊gas費太高,其他公鏈的gas費極低。
主要原因在于共識算法,以太坊仍是在用1.0鏈做交易驗證,也就是使用PoW算法,而其他公鏈大部分都使用了PoS或者改進的PoS、PoW。
本文中我們將分析幾種共識算法,來展現不同算法的區別。
一個分布式系統是由多個節點組成,節點之間需要網絡發送消息通信,根據它們遵循的協議在某個任務消息達成共識并一致執行。這個過程中會出現很多類型的錯誤,
第一類錯誤是節點崩潰、網絡故障、丟包等,這種錯誤類型的節點是沒有惡意的,屬于非拜占庭錯誤。
第二類錯誤是節點可能是惡意的,不遵守協議規則。例如驗證者節點可以延遲或拒絕網絡中的消息、可以提出無效塊、可以向不同的對等體發送不同的消息。在最壞的情況下,惡意節點可能會相互協作。這些被稱為拜占庭錯誤。
考慮到這兩種錯誤,系統始終徐亞保持兩個屬性:安全性(safety)和活躍性(liveness)。
金色午報 | 5月17日午間重要動態一覽:7:00-12:00關鍵詞:GBTC、比特幣暴跌、CME BTC期貨
1. 數據:價值16513枚比特幣的GBTC份額將于本周解鎖
2. “比特幣暴跌”排名微博熱搜榜第25位
3. 三菱東京日聯銀行:美元將維持疲軟
4. Galaxy Digital報告:銀行系統所消耗的能源是比特幣所消耗能源的兩倍以上
5. Vitalik Buterin銷毀410萬億枚SHIB,占SHIB總供應量的約41%
6. CME BTC期貨本周形成“45295-49140美元”缺口[2021/5/17 22:10:30]
安全性:在以上兩類錯誤發生時,共識系統不能產生錯誤的結果。在區塊鏈的語義下,指的是不會產生雙重花費和分叉。
活躍性:系統一直能持續產生提交,在區塊鏈的語義下,指的是共識會持續進行,不會卡住。假如一個區塊鏈系統的共識卡在了某個高度,那么新的交易是沒有回應的,也就是不滿足liveness。
BFT
BFT(拜占庭容錯協議)是一種即使系統中存在惡意節點也能保證分布式系統的安全性和活躍性的協議。根據Lamport論文,所有BFT協議都有一個基本假設:節點總數大于 3f 時,惡意節點最大為 f ,誠實節點可以達成一致的正確結果。
金色晨訊丨11月11日隔夜重要動態一覽:21:00-7:00關鍵詞:最高人民檢察院,黎巴嫩,存款合約,Gemini
1.最高人民檢察院:虛擬貨幣支付資致使打擊難度增大;
2.黎巴嫩央行行長:計劃在2021年推出數字貨幣;
3.以太坊2.0存款合約質押量達到啟動所需的10%;
4.業內人士:數字人民幣有望漸進式地重構電子支付格局;
5.美國OCC代理署長:加密貨幣支付機制已扎根于金融主流;
6.CME比特幣期貨11月合約收報15355美元;
7.美股三大指數僅道瓊斯指數收盤上漲 區塊鏈概念股漲跌各異;
8.Cash App第三季度比特幣銷售量超全網開采量;
9.Gemini開發“wFIL”服務,使其本機代幣FIL在以太坊使用;
10.比特幣持續震蕩,日內最低報15112.15美元,最高報15397.38美元。[2020/11/11 12:15:23]
PBFT
實用拜占庭容錯算法(PBFT)是現實世界里首批能夠同時處理第一類和第二類錯誤的拜占庭容錯協議之一,基于部分同步模型,解決了之前BFT類算法效率不高的問題,將算法復雜度由節點數的指數級降低到節點數的平方級,使得拜占庭容錯算法在實際系統應用中變得可行。
PBFT正常流程為3階段協議:
金色晚報 | 6月21日晚間重要動態一覽:12:00-21:00關鍵詞:Bitfinex、以太坊2.0、波卡、Bakkt
1. 以太坊區塊容量已提升20%,開發者擔心DoS問題。
2. Bitfinex首席技術官:以太坊2.0很可能會被黑客重點關注。
3. 數據:CME比特幣期權快速增長 市場份額接近25%。
4. 波卡周報:主網啟動NPoS網絡 一周更新兩版本。
5. 北京互聯網法院馬臣云:區塊鏈的邏輯能夠為數據確權和數據交換形成支撐。
6. 區塊鏈入選影響中國會計從業人員的十大IT信息技術。
7. 數據:本周Bakkt比特幣月度期貨交易額為5300萬美元。
8. IOHK將在下個月的虛擬峰會上展示后Shelley階段發展的新路線圖。
9. 以太坊核心開發者PeterSzilagyi反對提高Gas上限至1250萬。[2020/6/21]
pre-prepare:主節點(Primary)廣播預準備消息(Preprepare)到各副本節點(Replica)
prepare:該階段是各個節點告訴其他節點我已經知道了這個消息,一旦某個節點收到了包含n-f 個prepare消息(我們將使用QC也就是Quorum Certificate來指代,下同)則進入prepared狀態
金色晨訊| 柬埔寨證監會主席:將對申請許可證的數字資產交易所進行監管:1.美國SEC高級顧問:穩定幣有可能被列入證券監管的范疇。
2.納斯達克上市公司Riot Blockchain準備推出數字貨幣交易所。
3.印度內閣:將允許該國進出口銀行研究分布式總賬和區塊鏈技術。
4.美國內華達州提出要求加密貨幣相關企業向美國工商部門注冊。
5.柬埔寨證監會主席:將對申請許可證的數字資產交易所進行監管。
6.順豐區塊鏈落地醫藥溯源、智慧農業、跨境溯源等多場景。
7.拉美電商巨頭MercadoLibre禁止加密貨幣廣告等進入平臺。
8.耶魯大學教授:加密貨幣的增加表明傳統貨幣不能滿足全部需求。
9.美國加州計劃利用區塊鏈建立水資源解決方案。[2019/3/17]
commit:該階段是各個節點以及知道其他節點知道了這個消息,一旦某個節點收到了n-f 個commit消息(QC)則進入committed狀態
視圖切換(viewchange)是PBFT最為關鍵的設計,當主節點掛了(超時無響應)或者副本節點集體認為主節點是問題節點時,就會觸發ViewChange事件,開始viewchange階段。
通信復雜度給PBFT的共識效率帶來了嚴重的影響,極大地制約了PBFT的可擴展性。
分析 | 金色盤面:XRP自支撐位向上反彈:金色盤面分析師表示:XRP自支撐位向上反彈,現報0.44美元,注意關注上方0.45美元阻力的壓制情況。[2018/8/3]
如何把通信復雜度降低提高共識效率,是BFT共識協議在區塊鏈場景中面臨的挑戰。針對BFT共識效率的優化方法,具有以下幾類:聚合簽名、通信機制優化、view-change流程優化。
PBFT,SBFT等協議具有獨立的view-change流程,當主節點出問題后才觸發。而在Tendermint、HostStuff等協議中沒有顯式的view-change流程,view-change流程合入正常流程中,因此提高了view-change的效率,將view-change的通信復雜度降低。
Tendermint 將roundchange(和viewchange類似)合入正常流程中,因此roundchange和正常的區塊消息commit流程一樣,不像PBFT一樣有單獨的viewchange流程,因此通信復雜度也就降低。
HotStuff參考Tendermint,也將視圖切換流程和正常流程進行合并,即不再有單獨的視圖切換流程。通過引入二階段投票鎖定區塊,并采用leader節點集合BLS聚合簽名的方式,
Hotstuff將傳統BFT的兩輪的同步BFT改為三輪的鏈式BFT,沒有明確的prepare,commit共識階段,每個區塊只需要進行一輪QC,后一個區塊的 prepare 階段為前一個區塊的 pre-commit 階段,后一個區塊的 pre-commit 階段為前一個區塊的 commit 階段。每次出塊的時候都只需要低通信復雜度,通過兩輪的通信復雜度,達到了之前的效果。
PBFT、Tendermint等協議具有即時確定(Instant Finality)的特性,幾乎不可能出現分叉。在PBFT中,每個區塊被確認后才能出下一個區塊,Tendermint還提出區塊鎖定的概念,進一步確保了區塊的即時確定性,即在某個round階段,節點對區塊消息投了pre-commit票,則在下一個round中,該節點也只能給該區塊消息投pre-commit票,除非收到新proposer的針對某個區塊消息的解鎖證明。
這類BFT共識協議本質上是一個同步系統,將區塊的生產和確認緊密耦合,一個區塊確認后才能生產下一個區塊,需要在塊與塊間等待最大的可能網絡延遲,共識效率受到很大的限制。
PlatON:CBFT
CBFT基于部分同步網狀通信模型,提出了一個三階段共識的并行拜占庭容錯協議。網狀的通信模型更適合公網的弱網環境。
CBFT 的正常流程和Hotstuff類似,分為prepare,pre-comit,commit 和 decide幾個階段。但 CBFT 還作了關鍵的改進:在一個視圖窗口內可以連續提議多個區塊,下一個區塊的產生不用等上一個區塊達到QC;而且各個節點可以在接收上一個區塊投票的同時,并行執行下個區塊的交易,以 pipeline 的方式對區塊進行投票確認, 從而極大提高了出塊速度。
CBFT 有自適配的視圖切換機制:在一個視圖窗口內,節點接收到足夠多的區塊以及贊成票(超過2/3的節點投票,也就是 QC)時,會自動進行窗口切換,切換到下一個窗口,無需進行 viewchange 投票。除此之外,節點會啟動 viewchange 流程,并且在 viewchange 階段引入了和 Hotstuff 一樣的二階段鎖定投票規則,同時使用 BLS 聚合簽名,可以在低的通信復雜度內完成視圖窗口切換。
CBFT 只在正常流程之外才會進行 viewchange,因此相比 HotStuff 會有更少的視圖切換開銷。
CBFT共識中,每430個區塊(稱為一個 Epoch)就會更新驗證人集合,更新規則如下:
新驗證人可能由于網絡連接或區塊不同步等原因不能參與共識,因此我們每次替換不超過14個節點,如果候選驗證人不足14個,替換的數量為候選驗證人的總數。使用VRF從候選驗證人中隨機選出新驗證人。
Conflux:GHAST
Conflux 可以實現與比特幣和以太坊相同水平的去中心化和安全性,但在交易吞吐量(TPS)和最終延遲方面提供了兩個數量級以上的改進。
主要優勢在于共識協議、認證存儲和交易中繼協議。在 Conflux 分類帳中,塊被組織為樹形圖,其中每個塊引用一些其他塊,其中一個是其父塊。僅查看與父邊鏈接的塊,賬本似乎是一個樹結構(父樹),而查看所有塊,它似乎是一個有向無環圖。這也是將 Conflux 的賬本結構稱為 Tree-Graph 的原因。
Conflux 的共識算法,稱為 Greedy-Heaviest-Adaptive- SubTree (GHAST),通過在賬本中的父樹上應用最重子樹規則,使區塊鏈網絡中的所有節點能夠一致地就區塊的樞軸鏈達成一致,進而基于樞軸鏈就所有區塊的總順序達成共識。GHAST 還允許 Conflux 節點檢測一些可能損害活躍性的攻擊(例如,嘗試生成兩個平衡子樹的平衡攻擊),即確認交易的能力,并通過自適應調整塊的權重來阻止這些攻擊。
Tree-Graph 賬本和 GHAST 共識算法使 Conflux 節點能夠快速生成新塊,而不必擔心賬本中存在分叉可能會損害網絡的安全性,從而使系統能夠同時實現高吞吐量以及低交易確認延遲。
其他思路
Dfinity
Dfinity更改共識算法上,將傳統的共識節點全部參與共識計算修改為通過計算隨機數選取部分節點完成共識計算,這是加快共識驗證的一個步驟。而更核心的是選中的共識節點是通過非交互式的BSL算法(節點確認數據簽名反饋是獨立進行的,不是組合進行的)確認交易,意味著不會經歷BFT類共識的節點間反復交互的過程,而達到類似“并行”加速的效果。
IOTA
IOTA對算法的修改比較徹底,對比區塊鏈,IOTA使用Tangle數據結構形成總帳本Tangle特點是每個事務都附加到兩個先前的事務里,所以要完全消除了原有區塊鏈鏈式結構對確認時間的依賴。這就形成了交易的無限關聯確認結構,可以達到并行效果。
Filecoin
Filecoin在并行上的修訂,是在對存儲任務的并行處理,因為Filecoin的存儲部分,會對存儲數據完全進行計算,這個過程極為漫長(對比來說)。所以并行和提速非常之重要,目前,其采用的是更新后的NSE算法。
拆分NSE算法可以看到的是,當處理數據時,會對數據進行分window(可以理解為一個單元)和分layer層的處理,處理完成后才會進行下一步數據存儲以及后續的Post證明打包。采用NSE后,在layer的處理部分,layer間沒有過多依賴,所以可以形成并行處理效果,可以總結為并行提速的調整。
Tags:BFTCHAChangeHANbft幣最新消息KVI ChainGlobiance ExchangeELEPHANT價格
在過去的一年,由于加密市場的火熱,和各個項目的激烈角逐,這樣高速的發展不僅使加密貨幣總市值刷新了歷史新高,同樣也帶來了安全隱患,行業內安全事件頻發,黑客盜幣的金額也打破了往年歷史記錄.
1900/1/1 0:00:00每個 Web3 項目都離不開代幣分配。作為生態系統的核心,代幣是權益的新形式。代幣通常具有治理權,并允許社區成員作為共享資金庫的共同所有者成為產品、服務或協議的關鍵決策者.
1900/1/1 0:00:00Curve.fi — Defi世界中的TVL王者,Curve.fi在功能上并非一個復雜的defi產品,但是依托Curve.fi派生的生態體系卻錯節盤根,正在以巨大的能量影響著整個Defi世界.
1900/1/1 0:00:00來源 |?騰訊科技 2021年,如果有什么東西能夠吸引全球的目光,那元宇宙一定榜上有名。打開手機,元宇宙的信息便會躍然“屏”上,各行各業對于元宇宙的討論此起彼伏,乃至于有人笑稱“萬物皆可元宇宙”.
1900/1/1 0:00:00我發現,在社會上才華橫溢的人更像彗星,而不是恒星。他們有時會在一個環境里取得了巨大的成功,直到他們離開一家公司前往另一家公司并迅速失敗.
1900/1/1 0:00:00自Facebook宣布更名后,似乎每個人都在談論「元宇宙」。與此同時,著名導演細田守的最新動畫電影《Belle》正在宣傳期,這部電影巧妙演繹了“美女與野獸“,場景設定在一個元宇宙般的虛擬世界中.
1900/1/1 0:00:00