https://blog.youkuaiyun.com/simple_the_best/article/details/77198837
这篇文章的这张图把Tendermint的共识描述的差不多了:

1 Propose(r)生成区块广播,所有validator收到Block后,Prevote Block
2 节点收到2/3的prevote后,继续Precommit Block
3 节点收到2/3的precommit后,共识达成。各个validator Commit Block,然后开始下一轮共识
关于为什么要有Prevote和Precommit的两个2/3共识,是由BFT共识决定的:
我们以共识一个区块为例,出块节点广播一个区块后,需要对此区块达成共识后才算完成。跟POW不同的是,POW验证了区块就已经达成了共识(共识的是工作量),但是BFT此时并没有完成共识,节点需要知道有没有+2/3节点对此区块达成共识,所以每个节点还需要广播对区块的共识。
所以是首先需要+2/3节点对此区块达成共识,达成共识之后要广播对此区块的共识,最终所有节点收到+2/3对区块共识的共识之后,共识才算完成
Tendermint的prevote对应着对区块的共识,precommit对应着对区块共识的共识。比较拗口,多想想应该可以想明白

这张图表示的是BFT的共识步骤,C可以表示为节点0的client,0,1,2,3代表BFT节点,其中3为offline节点
结合这张图我们再详细介绍一下BFT的共识:
1 节点0 request生成区块,pre-prepare广播区块到1,2,3节点
2 prepare:1,2节点收到区块后,对区块达成共识后广播{对区块共识},对应Tendermint的prevote
3 commit:节点收到+2/3{对区块共识}后,再广播{对{对区块共识}的共识},对应Tendermint的precommit
4 reply:节点收到+2/3{对{对区块共识}的共识},共识完成。
本文详细解析了Tendermint的BFT共识过程,通过Propose、Prevote和Precommit三个阶段达成共识。BFT共识要求2/3节点对区块及区块的共识达成一致,以确保系统的稳定性和安全性。Tendermint的prevote阶段对应区块共识,precommit阶段则对应对区块共识的共识。

5286

被折叠的 条评论
为什么被折叠?



