zab协议

本文详细解析了ZooKeeper集群中Leader选举机制,包括LOOKING、LEADING和FLOWING三种状态的转换过程,以及客户端写入数据时采用的两阶段提交方式确保一致性。Leader负责决策所有读写请求,通过消息队列协调Follower节点。

一.选举过程
实例有三种状态,LOOKING、LEADING、FLOWING,当节点新加入到集群是LOOKING状态,如果有LEADING状态的leader发送消息,则进入FLOWING状态,并将leader的发送的zxid保存到本地。
如果集群没有leader,则发送自己的sid、zxid给其他机器,其他实例收到后与本地的zxid进行比较,若自己的大则不会投票给对方,并发起选举自己的投票信息。若某台机器收到超过一半的响应,则进入LEADING状态,选举成功。
二.客户端写入数据过程
所有的数据读写都要发送给leader决策,如果客户端发送请求给其他flowing节点,会转发给leader。
使用两阶段提交的方式进行一致性保证,leader与其他flower之间的通信使用消息队列。
a.收到写入请求,生成自增唯一zxid,将数据写入本地,并发送到消息队列给其他flower消费。当leader收到超过一半的响应时则认为数据写入成功,在本地进行提交。
b.本地提交后发送提交请求到消息队列,让其他flower进行提交。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值