區(qū)塊鏈共識機制與它的演進,是由于區(qū)塊鏈式去中心化而且分布式的系統(tǒng),必須要有一套放諸四海皆準類似憲法的規(guī)則,來規(guī)范如何證明誰能夠獲得記賬的權利全并且得到獎勵,還有意圖危害系統(tǒng)將會受到甚么懲罰,來維持整個系統(tǒng)穩(wěn)定發(fā)展。
區(qū)塊鏈(Blockchain)其實就是賬本串連在一起,每一塊的賬本都記錄著我們的交易,再計算出每塊賬本的Hash(藝術哈希值)表示。而每一塊賬本的Hash,會放在下一個賬本的最前面,跟著這些帳本的交易紀錄變成一個新的Hash,這表示如果你不能單單竄改了一個區(qū)塊的交易紀錄,后面的區(qū)塊也需要一起更改。在這種條件下的竄改機率幾乎等于零。這就是為什么大家會說區(qū)塊鏈是不可篡改的,以下為我們常見的共識算法。
PoW(Proof of Work,工作量證明),也就是付出的越多,那就可以獲得越多的獎勵,常見的比特幣(BTC)以及以太幣(ETH)皆是采用這種共識算法。一般來說,礦工們會透過CPU、GPU或ASIC來進行挖礦,主要過程?概是猜?個名為Nonce的數(shù)值,第一個找到Nonce值經過函數(shù)之后小于某一個值的礦工就獲勝,可以獲得出塊的權利。雖然PoW可以讓整體網(wǎng)絡相對去中心化,但確認交易的速度卻相當緩慢,這也使得區(qū)塊鏈想要融入我們日常的生活有不少阻力。另一方面,當越來越多的礦工投入時,便造成了大量的能源浪費。為了改善交易速度以及減少耗能,所以產生了另外一個共識機制?—?PoS(Proof of Stake)。
PoS(Proof of Stake,權益證明)。主要便是希望可以解決PoW運算時消耗過多能源的缺點,不同于PoW透過計算能力競爭記賬權,PoS是依照所持有幣的數(shù)量,當你持有的越多就代表有越大的機率可以取得記賬權力,因此PoS免去了礦機消耗的龐?電?資源,但區(qū)塊鏈擴容與交易確認速度過慢的問題仍然未能解決。
代理權益證明DPoS(Delegated Proof of Stake)
為了解決目前PoW遇到的耗能費時問題以及PoS仍舊無法突破的擴容、效率問題,Daniel Larimer(BM)提出了新的共識機制DPoS,BM除了是EOS的創(chuàng)始人也曾經開發(fā)過Bitshares(2014)還有Steem(2016),兩個項目都采用DPoS共識機制,區(qū)塊鏈網(wǎng)絡運行到現(xiàn)在的穩(wěn)定程度,已經能夠證明DPoS共識機制是可行的,從交易紀錄的活躍程度來看,透過DPoS共識機制的區(qū)塊鏈性能是目前區(qū)塊鏈網(wǎng)絡中最高的。
作為第三代的共識機制,就是為了解決前兩代痛點而出現(xiàn),保留了PoS節(jié)能的優(yōu)點,并引入了代議民主的概念,每一顆EOS都是一張選票,藉由選票選出21個Block Producer(超級節(jié)點),透過減少節(jié)點的數(shù)量,除了能夠達成比PoS更低的能耗,更是解決了PoW與PoS其中一個痛點?—?交易確認的時間過長的問題。
如果覺得DPoS的概念太過抽象難以理解,可以把DPoS想像成一間公司,而21個超級節(jié)點就是公司的21個董事與大股東,負責參與大公司大事的決策,由于成為超級節(jié)點的大股東,手上都握有極大份額的股分,常理來說并不會做出對公司未來有害的決策,若真的有股東做出不智的決定,所有的股分持有者也可以透過手上的幣作為選票來讓這名對公司有危害的大股東下臺。
DPoS的構架把所有利益關系人串聯(lián)起來,讓所有參與者不再是互為競爭者而是合伙人。雖然眾多人批評這種代議式民主的方式有違了區(qū)塊鏈去中心化的初衷,但仔細目前BTC以及ETH的算力分布,BTC前10大礦池就已經把持了超過86%的算力;ETH更是集中,前五大就超過了75%。
另一方面,要將區(qū)塊鏈融入我們的生活中必要的條件就是快速的交易確認,當我們藉由虛擬貨幣從事任何一種支付行動的時候都希望可以和我們目前的日常支付沒有過大的差異。然而BTC以及ETH卻無法達成,光等待確認的時間就至少需要20分鐘了,可想而知,我們是無法想像要買一杯珍奶需要站在柜臺等待20分鐘的。而DPoS透過代議式的民主機制,選出21個節(jié)點來幫EOS網(wǎng)絡來進行確認,這樣便可大幅縮短等待確認的時間,進而讓更多的實際應用變成可能。
在區(qū)塊鏈中,不可能的三角分別為:可擴展性、去中心化以及安全。而從DPoS中很明顯的可以發(fā)現(xiàn)到降低了去中心化這個部分,進而達到了高TPS。整個區(qū)塊鏈行業(yè)還在發(fā)展的早期階段,DPoS只是提供了我們一個可能的想像,也期待在日后透過社群的腦力激蕩,可以將不可能的三角化為可能。