zookeeper的选举过程

zookeeper的选举过程大致如下:


zookeeper的选举过程,就是选出一个在n/2+1个节点中选出一个节点为主节点的过程。比如,当我们启动一个有5个节点的zookeeper集群的时候。首先启动server1,然后server1选举自己为leader,但是现在只有1个节点,所以无法确定leader,server1就处于looking状态;

然后启动server2,这个时候server2也是选举自己为leader,和server1比较一下id,发现server2的id大,所以选举server2为leader,但是现在集群节点数还是小于3,然后启动server3,server3根据接受到的信息,比较后发现,server3的id最大,所以server1,server2,server3都选举server3为leader;

因为此时有3个选了server3为leader,然后3>=3,所以server3为leader,server1,server2为follower,然后启动server4,和server5,这个时候因为server3已经是leader,所以server4与server5只能是follower状态;


这个是初次启动的状态,如果不是初次启动的话,还需要判断各个server里面保存消息的状态是否是最新的。如果是最新的,再去找id最大的。选举也和初次是一样的。

原文地址:https://www.cnblogs.com/xjh713/p/7309436.html