一.选举过程
实例有三种状态,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进行提交。
zab协议
最新推荐文章于 2024-05-16 22:54:28 发布