区块链实验室(28) – 拜占庭节点劫持区块链仿真


在以前的FISCO环境中仿真拜占庭节点攻击区块链网络。该环境共有100个节点,采用PBFT作为共识机制,节点编号分别为:Node0,Node,… ,Node99。这100个节点的前2010区块完全相同,自区块2011开始分叉。

(1)1个拜占庭节点:Node0

Node0 区块长度2020,Node1 – Node99区块长度2030。

在Node0上发起交易,Node0区块同步失败。

图片[1] - 区块链实验室(28) – 拜占庭节点劫持区块链仿真 - MaxSSL

在其他节点上交易成功,区块同步成功。

图片[2] - 区块链实验室(28) – 拜占庭节点劫持区块链仿真 - MaxSSL

这说明:100个节点中Node0被抛弃,99个节点仍能PBFT共识成功。

反过来,在Node99节点上发起同样的交易,成功。

图片[3] - 区块链实验室(28) – 拜占庭节点劫持区块链仿真 - MaxSSL

但Node0节点的区块未更新,节点被抛弃。

图片[4] - 区块链实验室(28) – 拜占庭节点劫持区块链仿真 - MaxSSL

(2)33个拜占庭节点:Node0 – Node32

Node0 – Node32 区块长度2020,Node33 – Node99区块长度2030

在Node0上发起交易,交易失败,区块长度未变。

图片[5] - 区块链实验室(28) – 拜占庭节点劫持区块链仿真 - MaxSSL

Node99节点的区块长度也未变,说明交易失败。

图片[6] - 区块链实验室(28) – 拜占庭节点劫持区块链仿真 - MaxSSL

反过来,在Node99节点上发起同样的交易,同样失败。

图片[7] - 区块链实验室(28) – 拜占庭节点劫持区块链仿真 - MaxSSL

Node0节点的区块长度也未变,交易彻底失败。

图片[8] - 区块链实验室(28) – 拜占庭节点劫持区块链仿真 - MaxSSL

此时,整个区块链失去共识能力。

(3)32个拜占庭节点:Node0 – Node31

Node0 – Node31 区块长度2020,Node32 – Node99区块长度2030

在Node0上发起交易,Node0的区块长度未变。

图片[9] - 区块链实验室(28) – 拜占庭节点劫持区块链仿真 - MaxSSL

但在Node99上区块长度加1,说明交易成功。

图片[10] - 区块链实验室(28) – 拜占庭节点劫持区块链仿真 - MaxSSL

相同地,在Node99上发起交易,交易成功,区块长度加1.

图片[11] - 区块链实验室(28) – 拜占庭节点劫持区块链仿真 - MaxSSL

然而,Node0节点的区块长度未变。

图片[12] - 区块链实验室(28) – 拜占庭节点劫持区块链仿真 - MaxSSL

此时,整个区块链还具有共识能力。结论:在FISCO环境中,PBFT共识的条件是N>3f+1,其中N是节点总数,f是拜占庭节点数量。

© 版权声明
THE END
喜欢就支持一下吧
点赞0 分享