Tendermint之BFT共识

理解Tendermint的BFT共识机制
本文详细解析了Tendermint的BFT共识过程,通过Propose、Prevote和Precommit三个阶段达成共识。BFT共识要求2/3节点对区块及区块的共识达成一致,以确保系统的稳定性和安全性。Tendermint的prevote阶段对应区块共识,precommit阶段则对应对区块共识的共识。

https://blog.youkuaiyun.com/simple_the_best/article/details/77198837

这篇文章的这张图把Tendermint的共识描述的差不多了:

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{对{对区块共识}的共识},共识完成。

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值