王 兵,李輝靈,牛新征
(1.西南石油大學(xué) 計(jì)算機(jī)科學(xué)學(xué)院,成都 610500;2.電子科技大學(xué) 計(jì)算機(jī)科學(xué)與工程學(xué)院,成都 611731)
區(qū)塊鏈的提出引起了學(xué)術(shù)界與業(yè)界的廣泛關(guān)注,其為集中式機(jī)構(gòu)的高成本、低效率和數(shù)據(jù)存儲(chǔ)[1]不安全性提供了解決方案[2]。區(qū)塊鏈底層是一系列技術(shù)集成的分布式賬本系統(tǒng),系統(tǒng)中每一個(gè)區(qū)塊的架構(gòu)包含了交易數(shù)據(jù)[3]、父區(qū)塊Hash 值[4]、Merkle 樹[5]等信息。根據(jù)技術(shù)的不同從下到上分為數(shù)據(jù)層、網(wǎng)絡(luò)層、共識(shí)層、激勵(lì)層、合約層、應(yīng)用層[6],且隨著技術(shù)的不斷發(fā)展,區(qū)塊鏈能夠與智能合約[7]相結(jié)合,并出現(xiàn)了許多的Dapp應(yīng)用[8-10],為現(xiàn)實(shí)世界提供了從信息到價(jià)值的傳遞功能。
區(qū)塊鏈中各節(jié)點(diǎn)能自發(fā)、誠(chéng)實(shí)地遵守協(xié)議中預(yù)先設(shè)定的規(guī)則并保持全局狀態(tài)一致,共識(shí)算法起著至關(guān)重要的作用。工作量證明(Proof of Work,PoW)[11-12]機(jī)制作為主流的共識(shí)算法之一,其依賴計(jì)算機(jī)算力競(jìng)爭(zhēng)記賬權(quán),一個(gè)新的區(qū)塊生成需要計(jì)算出符合條件的哈希值,但算力爭(zhēng)奪會(huì)消耗大量資源。為減緩資源的大量消耗,研究人員提出權(quán)益證明(Proof of Stake,PoS)[13]共識(shí)算法,根據(jù)持有數(shù)字貨幣數(shù)量和時(shí)間來分配相應(yīng)利息的制度。PoS 的進(jìn)一步演變是股份授權(quán)證明(Delegate Proof of Stake,DPoS)[14]共識(shí)算法,其原理是讓每一個(gè)股份節(jié)點(diǎn)進(jìn)行投票,由此產(chǎn)生權(quán)利對(duì)等的101位委托人節(jié)點(diǎn)。隨著聯(lián)盟鏈共識(shí)機(jī)制[15]的興起,實(shí)用拜占庭容錯(cuò)(Practical Byzantine Fault Tolerance,PBFT)[16]共識(shí)算法被提出,按照少數(shù)服從多數(shù)原則,經(jīng)主節(jié)點(diǎn)提交提議至其他共識(shí)節(jié)點(diǎn)進(jìn)行確認(rèn),當(dāng)超過2/3 的節(jié)點(diǎn)確認(rèn)后則提議通過[17]。Raft[18]可作為一種典型的聯(lián)盟鏈共識(shí)算法,該算法包含3 種角色,分別是跟隨者、候選人和領(lǐng)導(dǎo)者,這3 種角色能隨著時(shí)間和條件的變化而互相轉(zhuǎn)換。
本文提出一種基于綜合選舉的DPoS(Comprehensive Election DPoS,CE-DPoS)共識(shí)算法。該算法摒棄原DPoS 按股份投票的方式,節(jié)點(diǎn)之間能夠根據(jù)自身意愿進(jìn)行投票,在符合現(xiàn)實(shí)情況的同時(shí),新節(jié)點(diǎn)的加入不受股份的影響,提升了節(jié)點(diǎn)之間的投票活躍度。DPoS 節(jié)點(diǎn)的通信代價(jià)主要受前置節(jié)點(diǎn)和后置節(jié)點(diǎn)的影響,而CE-DPoS 共識(shí)算法根據(jù)預(yù)設(shè)的網(wǎng)絡(luò)信息表選取節(jié)點(diǎn),以降低網(wǎng)絡(luò)通信消耗。
DPoS 共識(shí)算法憑借低延時(shí)、出塊時(shí)間短、高吞吐量、幾乎不分叉的特點(diǎn)及優(yōu)勢(shì),得到了研究人員的廣泛使用[19],區(qū)塊鏈架構(gòu)如圖1 所示。DPoS 相較于PoW 有更低的能源消耗,減少了硬件資源的消耗,且繼承了PoS的股份思想,具有比PoS 更快的效率和更高的性能。DPoS 共識(shí)算法在選舉委托人節(jié)點(diǎn)過程中,由持有股份的節(jié)點(diǎn)相互投票(投票權(quán)重與股份成正比),即每個(gè)股東節(jié)點(diǎn)可以將其持有的股份作為選票授予一個(gè)代理人,最終選定的節(jié)點(diǎn)為票數(shù)靠前的n個(gè)節(jié)點(diǎn),選定的n個(gè)節(jié)點(diǎn)輪流進(jìn)行打包交易和出塊。但持有股份越多的節(jié)點(diǎn)當(dāng)選委托人節(jié)點(diǎn)的概率極大,造成了弱中心化,并容易導(dǎo)致Dos 攻擊[20]。
圖1 區(qū)塊鏈結(jié)構(gòu)Fig.1 Structure of blockchain
由此,許多學(xué)者對(duì)DPoS 共識(shí)算法做了進(jìn)一步優(yōu)化。文獻(xiàn)[21]提出了節(jié)點(diǎn)的升降機(jī)制,從對(duì)惡意節(jié)點(diǎn)的識(shí)別角度出發(fā),對(duì)良好節(jié)點(diǎn)和惡意節(jié)點(diǎn)通過降級(jí)的方式加以區(qū)分。文獻(xiàn)[22]在節(jié)點(diǎn)升降的基礎(chǔ)上引入了誠(chéng)實(shí)節(jié)點(diǎn)的動(dòng)態(tài)選舉,有效降低選取惡意節(jié)點(diǎn)的概率,但對(duì)節(jié)點(diǎn)投票活躍度沒有明顯提升。文獻(xiàn)[23]引入了信用值,為每一個(gè)節(jié)點(diǎn)設(shè)定一個(gè)信用值,信用值作為當(dāng)選委托人節(jié)點(diǎn)的一個(gè)重要參考指標(biāo),每輪共識(shí)結(jié)束后信用值發(fā)生改變,但信用值的積累可能導(dǎo)致信用值高者越高的情況。文獻(xiàn)[24]將DPoS 中的節(jié)點(diǎn)分為不同的信譽(yù)狀態(tài),同樣可能導(dǎo)致信譽(yù)值高的節(jié)點(diǎn)一直處于高信譽(yù)的問題。從優(yōu)化投票的角度出發(fā),文獻(xiàn)[25]提出細(xì)化投票的思想,其中包括支持票、棄權(quán)票、反對(duì)票,通過3 種方式度量節(jié)點(diǎn)的意愿投票傾向,文獻(xiàn)[26]根據(jù)細(xì)化的投票方式又做了進(jìn)一步優(yōu)化,增加10 分支持票、10 分反對(duì)票的投票方式,改善了單一投票的方式,但不能完全滿足現(xiàn)實(shí)狀況的實(shí)際投票人的意愿權(quán)重。
由于經(jīng)典DPoS 共識(shí)算法選舉節(jié)點(diǎn)固定單一,且始終是股份占比較大的節(jié)點(diǎn),導(dǎo)致股份占比少的節(jié)點(diǎn)活躍度急劇下降。同時(shí)選舉出委托人節(jié)點(diǎn)后,出塊順序未考慮節(jié)點(diǎn)之間的通信消耗,加大了出塊時(shí)間。針對(duì)上述問題,本文提出一種CE-DPoS 共識(shí)算法。每個(gè)節(jié)點(diǎn)根據(jù)自身的意愿相互投票,在一輪共識(shí)投票結(jié)束后,模型網(wǎng)絡(luò)會(huì)計(jì)算出每個(gè)節(jié)點(diǎn)的最終加權(quán)票數(shù),并進(jìn)行降序排列。每個(gè)節(jié)點(diǎn)在加入?yún)^(qū)塊鏈網(wǎng)絡(luò)前,會(huì)和網(wǎng)絡(luò)中的其他節(jié)點(diǎn)進(jìn)行通信,隨后根據(jù)通信的代價(jià)建立自身節(jié)點(diǎn)的網(wǎng)絡(luò)信息表,網(wǎng)絡(luò)信息表中存儲(chǔ)的是與自身通信開銷最小的某些節(jié)點(diǎn)。最終依據(jù)網(wǎng)絡(luò)的連接情況,依次動(dòng)態(tài)選擇通信量少并且分值最大的節(jié)點(diǎn)。
在公有鏈網(wǎng)絡(luò)中,節(jié)點(diǎn)參與活躍度與網(wǎng)絡(luò)的安全性息息相關(guān),在經(jīng)典DPoS 共識(shí)算法中,節(jié)點(diǎn)投票有失公平性,節(jié)點(diǎn)出現(xiàn)投票政治冷漠性。為極大程度地滿足節(jié)點(diǎn)的投票意愿傾向和公平性,對(duì)投票意愿設(shè)置等級(jí)。CE-DPoS 投票模型中的符號(hào)說明如表1 所示。
表1 符號(hào)說明Table 1 Symbol description
設(shè)定投票權(quán)重為Si,其中Si={i|i=1,2,3,4,5},權(quán)重依次遞增為:S1≤S2≤S3≤S4≤S5,投票意愿分別對(duì)應(yīng)于[0~19%]、[20%~39%]、[40%~59%]、[60%~79%]、[80%~100%]。CE-DPoS 和DPoS 共識(shí)算法中最大投票數(shù)相同,每個(gè)節(jié)點(diǎn)至多對(duì)其他30 個(gè)節(jié)點(diǎn)投票。本文通過實(shí)驗(yàn)仿真進(jìn)行模擬投票,統(tǒng)計(jì)投票信息的權(quán)重占比,若曲線出現(xiàn)近似正態(tài)分布,權(quán)重S1、S2與權(quán)重S5投票數(shù)大致相同,且均低于投票權(quán)重S3、S4,便于系統(tǒng)票數(shù)的計(jì)算,采用3 個(gè)集合Γ1、Γ2、Γ3進(jìn)行票數(shù)的統(tǒng)計(jì):Γ1代表投票意向?yàn)椋?,39%],集合中投票評(píng)分對(duì)應(yīng)S1、S2;Γ2代表投票意向?yàn)椋?0%,79%],集合中投票評(píng)分對(duì)應(yīng)S3、S4;Γ3代表投票意向?yàn)椋?0%,100%],集合中投票評(píng)分對(duì)應(yīng)S5。
設(shè)節(jié)點(diǎn)收到其他節(jié)點(diǎn)的投票數(shù)為m(m值不涉及投票分值,一個(gè)節(jié)點(diǎn)參與投票即一票),節(jié)點(diǎn)對(duì)另一個(gè)節(jié)點(diǎn)評(píng)分值用Φ表示,其中Φi表示第i個(gè)節(jié)點(diǎn)的評(píng)分值。所有投票分值的中位數(shù)為,平均值為,節(jié)點(diǎn)最終分值如式(1)所示:
表2 列舉了3 個(gè)節(jié)點(diǎn)的得票情況,節(jié)點(diǎn)之間對(duì)其他節(jié)點(diǎn)進(jìn)行權(quán)重投票。
表2 節(jié)點(diǎn)得票數(shù)Table 2 Number of votes by the node
按照式(1)計(jì)算得到節(jié)點(diǎn)的最終分值:
不失一般性,設(shè)當(dāng)前有11 個(gè)節(jié)點(diǎn)參與投票,則對(duì)于11 個(gè)候選節(jié)點(diǎn)出現(xiàn)的得票權(quán)可能性p如式(2)所示:
其中:mi表示票權(quán)為i的票數(shù)總和。
節(jié)點(diǎn)投票出現(xiàn)的所有可能結(jié)果以概率的形式表示,所有結(jié)果的概率之和為1,如下式所示:
通過計(jì)算,將節(jié)點(diǎn)得分按降序排列:
在網(wǎng)絡(luò)信息表的基礎(chǔ)上,選定所有節(jié)點(diǎn)中分?jǐn)?shù)排名最高的節(jié)點(diǎn)A,從節(jié)點(diǎn)A網(wǎng)絡(luò)信息表中選出除節(jié)點(diǎn)A外分?jǐn)?shù)排名最高的節(jié)點(diǎn)B,再?gòu)墓?jié)點(diǎn)B網(wǎng)絡(luò)信息表中選出除B外分?jǐn)?shù)排名最高的節(jié)點(diǎn)C,直至選定n個(gè)委托人節(jié)點(diǎn),整體過程如圖2 所示。
圖2 CE-DPoS 委托人節(jié)點(diǎn)選舉流程Fig.2 Procedure of CE-DPoS delegate node election
區(qū)塊鏈網(wǎng)絡(luò)中的交互主要通過節(jié)點(diǎn)之間的通信,通信快慢直接或間接影響著整個(gè)區(qū)塊鏈的性能。文獻(xiàn)[27]定義了節(jié)點(diǎn)發(fā)生沖突塊的概率Pr(F=0),如式(3)所示:
其中:T為區(qū)塊最大傳播時(shí)延;G(t)代表多個(gè)區(qū)塊傳播給節(jié)點(diǎn)的概率積累值;P為挖礦難度。
區(qū)塊傳播時(shí)間定義如式(4)所示:
將式(4)變形得到:
其中:G(t)=,最終得出Pr(F≥1)≈P×ns×D。結(jié)果表明出塊概率與區(qū)塊傳播時(shí)間成正相關(guān)。
在DPoS 共識(shí)算法中,委托人節(jié)點(diǎn)之間的傳播主要是與后面一個(gè)節(jié)點(diǎn)通信,因此節(jié)點(diǎn)之間依靠通信代價(jià)最小的連接是提高性能的一種方式。
本文設(shè)置節(jié)點(diǎn)網(wǎng)絡(luò)信息表用于保存每個(gè)節(jié)點(diǎn)與自己一定距離范圍內(nèi)(通信代價(jià))其他節(jié)點(diǎn)的連接信息。為防止節(jié)點(diǎn)選舉發(fā)生網(wǎng)絡(luò)風(fēng)暴,進(jìn)而導(dǎo)致無(wú)法選取出委托人節(jié)點(diǎn),設(shè)定每個(gè)節(jié)點(diǎn)與其他節(jié)點(diǎn)連接數(shù)為k,k≥n-1,其中k為固定值,n為選取的委托人節(jié)點(diǎn)總數(shù)。在節(jié)點(diǎn)加入網(wǎng)絡(luò)時(shí),向其他節(jié)點(diǎn)進(jìn)行通信,當(dāng)節(jié)點(diǎn)N1每收到一個(gè)返回消息時(shí),發(fā)送者N2的IP 地址就被用來更新對(duì)應(yīng)的網(wǎng)絡(luò)信息表。如果N2的IP 地址沒有記錄在該信息表中,則N1節(jié)點(diǎn)的記錄項(xiàng)小于k個(gè),記錄N2至自身信息表中;如果節(jié)點(diǎn)N1的記錄項(xiàng)大于k個(gè),則對(duì)該節(jié)點(diǎn)信息表中的節(jié)點(diǎn)進(jìn)行檢測(cè)操作。出現(xiàn)節(jié)點(diǎn)沒有響應(yīng),從表中刪除無(wú)響應(yīng)的節(jié)點(diǎn),并插入N2節(jié)點(diǎn)。如果所有節(jié)點(diǎn)都有響應(yīng),則忽略N2。網(wǎng)絡(luò)信息表的建立具體流程如算法1~算法3 所示。
為測(cè)試模型的有效性,仿真實(shí)驗(yàn)設(shè)備配置為AMD Ryzen 5 3550H 處理器,16 GB 運(yùn)行內(nèi)存,Windows10 操作系統(tǒng),采用Docker 容器技術(shù),運(yùn)用編程語(yǔ)言通過多端口模擬多節(jié)點(diǎn)來實(shí)現(xiàn)節(jié)點(diǎn)的投票行為。共識(shí)協(xié)議假定節(jié)點(diǎn)之間是誠(chéng)信可靠的,并且網(wǎng)絡(luò)與最終交付確保是異步通信的,每個(gè)節(jié)點(diǎn)能通過可靠的通信鏈路連接。
本文設(shè)定從11 個(gè)節(jié)點(diǎn)中選擇4 個(gè)節(jié)點(diǎn)作為委托人節(jié)點(diǎn),此外,各節(jié)點(diǎn)相互之間能夠?qū)ζ渌?jié)點(diǎn)進(jìn)行權(quán)重為0~5 的對(duì)等投票,其中0 表示未進(jìn)行投票打分,圖3 展示了11 個(gè)節(jié)點(diǎn)相互投票的結(jié)果。
圖3 11 個(gè)節(jié)點(diǎn)互相投票結(jié)果Fig.3 Result of 11 nodes voting with each other
表3 所示為對(duì)圖3 結(jié)果的分析,將各個(gè)節(jié)點(diǎn)得分進(jìn)行統(tǒng)計(jì),計(jì)算出票權(quán)數(shù)總和Total 值,但會(huì)出現(xiàn)多個(gè)Total 值相等的情況,并不滿足實(shí)際的投票意愿,因此使用式(1)計(jì)算它們的偏差度,得出最終的分?jǐn)?shù)V#。
表3 節(jié)點(diǎn)得分票權(quán)占比和最終分值Table 3 Proportion of node’s scoring votes and final score
圖4 為本文預(yù)先設(shè)定的節(jié)點(diǎn)之間路由表的連接,連接數(shù)k設(shè)定為3(單向箭頭指向代表該節(jié)點(diǎn)網(wǎng)絡(luò)信息表中包含箭頭指向的節(jié)點(diǎn)),各個(gè)節(jié)點(diǎn)通過與其他節(jié)點(diǎn)的交互行為形成各自的網(wǎng)絡(luò)信息表,最終所有的節(jié)點(diǎn)共同維護(hù)全局網(wǎng)絡(luò)信息表,矩陣R表示路由連接信息,1 表示連接,0 表示未連接。
圖4 節(jié)點(diǎn)網(wǎng)絡(luò)信息表連接情況Fig.4 Connection status of node network information table
通過圖4 中各個(gè)節(jié)點(diǎn)之間的關(guān)系,采用局部最優(yōu)的思想,最終選取的委托人節(jié)點(diǎn)如表4 所示。
表4 委托人節(jié)點(diǎn)選取的最終結(jié)果Table 4 Final result selected by delegate node
本文模型中委托人節(jié)點(diǎn)的選取是動(dòng)態(tài)的,并且兼顧了各節(jié)點(diǎn)的票數(shù),選出的節(jié)點(diǎn)既滿足通信量小且得分較高。在一輪共識(shí)結(jié)束后,計(jì)算選出的4 個(gè)節(jié)點(diǎn)的分?jǐn)?shù)平均值,從剩下的7 個(gè)節(jié)點(diǎn)中隨機(jī)選取另外4 個(gè)節(jié)點(diǎn)并計(jì)算出平均值。最終分別計(jì)算出與一輪共識(shí)中最高分的比值,如式(5)所示:
重復(fù)共識(shí)選舉20 次,實(shí)驗(yàn)結(jié)果如圖5 所示。由圖5 可知,pa和pβ值呈現(xiàn)相似的波動(dòng)。隨著共識(shí)次數(shù)從0~20 的增長(zhǎng),使用CE-DPoS 共識(shí)算法選舉模型比隨機(jī)選取算法在滿足現(xiàn)實(shí)情況投票方面的優(yōu)勢(shì)更加突出。當(dāng)共識(shí)次數(shù)增加到15 次時(shí),CE-DPoS 共識(shí)的委托人選舉百分占比為97.23%,而同等條件下隨機(jī)選取委托人百分占比僅有91.05%。
圖5 選舉委托人節(jié)點(diǎn)分?jǐn)?shù)占比1Fig.5 Election delegate node score percentage 1
增加共識(shí)次數(shù)至100 次,結(jié)果如圖6 所示,隨著共識(shí)次數(shù)的增加,CE-DPoS 共識(shí)算法選取委托人百分占比整體波動(dòng)相對(duì)穩(wěn)定,而隨機(jī)選取波動(dòng)幅度較大。
圖6 選舉委托人節(jié)點(diǎn)分?jǐn)?shù)占比2Fig.6 Election delegate node score percentage 2
傳統(tǒng)DPoS 共識(shí)算法在選出節(jié)點(diǎn)后,委托人節(jié)點(diǎn)之間的先后通信方式?jīng)]有明確的規(guī)定,采用隨機(jī)的見證人出塊順序,出塊速度大致為3 s 左右。BFT-DPoS 共識(shí)算法選取委托人后互相協(xié)商出一個(gè)出塊的順序,見證人出塊時(shí)進(jìn)行全網(wǎng)廣播,其他見證人收到新區(qū)塊后,立即對(duì)此區(qū)塊進(jìn)行驗(yàn)證,不需等待其他見證人自己出塊時(shí)再確認(rèn)。CE-DPoS 共識(shí)算法通過設(shè)定網(wǎng)絡(luò)信息表記錄節(jié)點(diǎn)之間通信代價(jià),在信息表中依次選取委托人節(jié)點(diǎn),降低了隨機(jī)選取委托人節(jié)點(diǎn)之間不必要的通信消耗。
實(shí)驗(yàn)仿真3 種共識(shí)算法的出塊時(shí)間進(jìn)行對(duì)比,結(jié)果如圖7 所示。隨著區(qū)塊個(gè)數(shù)從0~1 000 的增長(zhǎng),使用CE-DPoS 共識(shí)算法比DPoS、BFT-DPoS 共識(shí)算法在降低出塊時(shí)間方面的優(yōu)勢(shì)更加突出。當(dāng)區(qū)塊個(gè)數(shù)增加到1 000 個(gè)時(shí),CE-DPoS 共識(shí)算法的出塊時(shí)間降至0.4 s,比同等條件下DPoS 共識(shí)算法節(jié)約了80%的時(shí)間,能更好地應(yīng)對(duì)日益增長(zhǎng)的交易量。
圖7 出塊時(shí)間對(duì)比Fig.7 Block time comparison
DPoS 共識(shí)算法由于存在去中心化程度低下、節(jié)點(diǎn)投票不積極等問題而被業(yè)界與學(xué)術(shù)界所詬病。本文實(shí)驗(yàn)仿真3 種共識(shí)算法,計(jì)算節(jié)點(diǎn)投票占比并將其進(jìn)行對(duì)比,結(jié)果如圖8 所示。隨著共識(shí)次數(shù)的不斷增加,使用CE-DPoS 共識(shí)算法比DPoS、BFT-DPoS共識(shí)算法在提升節(jié)點(diǎn)投票活躍度方面優(yōu)勢(shì)更加突出。由于DPoS 和BFT-DPoS 都采用股份的投票方式,股份較少的節(jié)點(diǎn)失去了投票的積極性,全局投票活躍度僅為34%左右,同程度的CE-DPoS 共識(shí)算法節(jié)點(diǎn)活躍度提升至85%。
圖8 節(jié)點(diǎn)活躍度對(duì)比Fig.8 Node activity comparison
DPoS 共識(shí)算法作為主流公有鏈共識(shí)算法,存在選擇委托人節(jié)點(diǎn)單一固定、委托人節(jié)點(diǎn)之間出塊順序采用隨機(jī)方式以及通信消耗成本較高的問題。本文提出一種意愿評(píng)分的模型方案,該方案節(jié)點(diǎn)相互評(píng)分,計(jì)算出每個(gè)節(jié)點(diǎn)的綜合分值,然后通過排序選取出當(dāng)前分?jǐn)?shù)最高的節(jié)點(diǎn),再按照網(wǎng)絡(luò)信息表的連接情況依次選擇出后續(xù)的委托人節(jié)點(diǎn)。實(shí)驗(yàn)結(jié)果表明,本文方案選擇的委托人節(jié)點(diǎn)之間的出塊順序與節(jié)點(diǎn)之間的通信密切相關(guān),能夠加快節(jié)點(diǎn)的出塊時(shí)間,滿足日益增大的交易量,并提升節(jié)點(diǎn)的投票活躍度。后續(xù)工作將進(jìn)一步優(yōu)化CE-DPoS 投票模型的時(shí)間復(fù)雜度,并應(yīng)用到實(shí)際場(chǎng)景中。