zab协议

一.选举过程
实例有三种状态,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进行提交。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值