Vitalik探討改進以太坊Casper CBC協議

近日,以太坊創始人Vitalik Buterin在布拉格舉行的Devcon4大會上,公佈了以太坊發展路線(也被稱爲以太坊2.0)的最新信息,其中有一些內容,譯者在以前的文章《以太坊2.0協議核心Beacon鏈詳解》中已經有所說起,而更新的內容包括新鏈將以Serenity爲名(以前被稱爲Shasper,意指分片和Casper的結合),其包含了Casper、分片、EWASM以及其餘一些協議,它會是一條新的區塊鏈,並與當前的以太坊PoW鏈同時存在,且相互鏈接。git

而在第一階段,以太坊開發者們將交付基礎beacon鏈,第二階段則是推出分片數據鏈,第三階段就是啓用狀態交易(EWASM),最後則是迭代、改進以及添加新技術。github

而在本文當中,咱們將探討beacon鏈的Casper共識機制,Casper共識機制其實有兩個大的版本,一個是Casper FFG(Vitalik版),而另外一個則是本文要講到的Casper CBC(Vlad版)。算法

如下內容譯自Vitalik最新發布的帖子《Casper CBC lite via committees安全

Casper CBC 的工做流程大體以下:bash

  1. 驗證者發出消息;數據結構

  2. 每則消息指定驗證者正在投票的區塊,而且還指定了驗證者從其餘驗證者處收到的最新消息。框架

  3. 驗證者正在投票的區塊,必須等於或繼承自GHOST分叉選擇規則的頭部區塊(使用其餘驗證者的最新消息做爲輸入)dom

  4. 惟一的削減條件是(i)上述規則,(ii)驗證者不能生成具備相同序列號的兩則消息,(iii)在後面的消息中,驗證者不能引用具備(比早期消息中的驗證者所引用的消息)更早序列號的消息;區塊鏈

  5. 最終肯定性是內生的:在某些時候,當有多輪驗證者對X的後代進行投票時,從數學上講,若是沒有大量驗證者發出無效消息,頭部就不可能切換到非X塊;而少於這個量的限制,可以使用各類啓發式算法進行檢測和測量。spa

下面是一個GHOST分叉選擇規則的實例。 字母A,B,C,D,E表明着最近發生的5次投票。

9234f5b1

第一個選擇在綠色和黃色塊之間。最後綠色塊獲勝了,這是由於有三張選票來自綠色塊,而只有兩張選票來自其競爭者黃色塊。第二次選擇是在紅色塊和藍色塊之間。而藍色塊以2:1的比分獲勝,而藍色塊只有一個橙色的子塊,因此橙色塊是獲勝者。

這樣作而致使的效率問題是顯而易見的:每則消息都須要引用它已經看到的全部其它消息,這可能會致使O(N^2)的數據複雜性;

本文探討了一種緩解數據複雜性的特定策略,相較於每一個驗證者的投票,都是在每一個其餘驗證者消息的GHOST分叉選擇規則進行評估,其中驗證者被明確地分配給m個其餘驗證者的私人委員會(多是32≤m≤256),而且在他們的消息當中,必須包含對這些m個驗證者簽名的引用。

這種引用能夠按序列號,或者經過這些簽名已包含在鏈中的位置來完成。削減條件可簡單地檢查這些消息其實是否表明GHOST分叉選擇評估m則其餘消息,而且計數器老是遞增的。

更具體地說:

  1. 對於接受一則消息的鏈,要麼 (i) 消息必須對鏈中的區塊進行投票,要麼(ii)該消息投票的鏈外(off-chain)區塊必須被歸入一個叔塊(uncle);

  2. 對於接受一個叔塊的鏈,這個叔塊的父塊必須 (i)是該鏈的一部分,或者(ii)已經被歸入了鏈中,並做爲一個叔塊;

  3. 對於一條接受一則消息的鏈,引用其最新集的全部消息,都必須被接受;

  4. 每則消息都有一個序列號。對於一條接受帶有序列號爲n消息的鏈,它必須已接受了來自序列號爲0….n−1驗證者的消息;

  5. 驗證者能夠對具備相同序列號的兩則消息進行削減處理,或者也能夠削減一則投票x的消息,其中消息中包含的證據不能證實投票x;

若是委員會足夠大,它們將接近整個驗證者集。而且你能夠試探性地肯定驗證者的數量。 下面是相關的代碼:

github.com ethereum/research/blob/659f0b31f9337b3e7ee4bde45cdb93c0ed4fd390/graph_cbc/graph_cbc.py
複製代碼
import randomVALIDATORS = 5000
EDGES = 255
FINALITY = 4000assert EDGES % 2 == 1neighbors = list(range(VALIDATORS))
edgelist = neighbors * EDGES
random.shuffle(edgelist)
edges = [edgelist[i*EDGES:i*EDGES+EDGES] for i in range(VALIDATORS)]last_votes = '1' * FINALITY + '0' * (VALIDATORS - FINALITY)while 1:
    new_zeroes = []
    for i in range(VALIDATORS):
        votes_for_0 = len([e for e in edges[i] if last_votes[e] == '0'])
        if votes_for_0 * 2 > EDGES:
複製代碼
注意,這部分代碼是截取的,完整代碼可訪問:https://github.com/ethereum/research/blob/659f0b31f9337b3e7ee4bde45cdb93c0ed4fd390/graph_cbc/graph_cbc.py
複製代碼

結果就是m ≈ 256 ,容錯率彷佛接近20%,很是接近 Casper CBC兩輪內最大的可能值25%。雖然咱們失去了幾個百分點的安全性,但咱們得到了一個使人驚訝的簡約協議表示,不然的話,就可能須要一些至關複雜的數據結構。

此外,請注意,這種Casper CBC的風格,基本上與Avalanche(雪崩協議)的工做方式很是類似,其中每一個節點經過對其餘節點委員會進行調查而得到共識。這裏的主要區別在於,委員會是經過協議選擇的,削減條件會強制執行合規性,而GHOST則被用做分叉選擇規則,以擴展N元共識鏈,從而有效地實現經濟安全。這代表可能存在着一個更爲通用的框架,它能夠有效地包含Casper CBC以及Avalanche;

進一步的工做:

  1. Casper CBC的容錯性,可經過增長的等待回合數,來提升到 (1/3-ϵ)。那麼咱們是否能夠用一種相似的技術,將容錯率提升到20%以上呢?

  2. 有沒有辦法,在這個設置當中讓分片天然地發生呢?通常而言,這種目標,可用某種DAG技術來替換鏈式機構來完成,其中每一個區塊都知道其分片的父級,以及其餘分片中的的第十個最新和較舊的區塊,而且指望驗證者,僅徹底驗證還沒有被足夠大的驗證者樣本所驗證的區塊;

原文:https://ethresear.ch/t/casper-cbc-lite-via-committees/3916

做者:Vitalik Buterin

編譯:灑脫喜

稿源(譯):巴比特資訊(http://www.8btc.com/casper-cbc-vitalik)

相關文章
相關標籤/搜索