选举算法模型
- 在创建选举算法的时候创建FastLeaderElection,在FastLeaderElection的构造函数中会创建Messenger实例、WorkerSender实例以及WorkerReceiver实例
- 调用FastLeaderElection的
start()
方法,最终启动WorkerSender和WorkerReceiver线程 - 选举过程中,服务器调用
FastLeaderElection.lookForLeader()
方法进行选举 - 服务器向集群中所有服务器发送自己的选票,待发送的选票存放于
FastLeaderElection.sendqueue
中 - WorkerSender不断从
FastLeaderElection.sendqueue
中获取待发送的信息,调用QuorumCnxManager.toSend()
发送投票信息 - WorkerReceiver不断调用
QuorumCnxManager.pollRecvQueue()
获取其他服务器发送过来的选票信息Message,将Message转化成Notification后存放于FastLeaderElection.recvqueue
中 - FastLeaderElection不断从
FastLeaderElection.recvqueue
中获取选票信息进行记录、统计,然后由SyncedLearnerTracker判断选票推举的leader是否获得足够的投票数量,如果数量过半则选举结束,否则继续
后文将逐步分析这些类,完后再分析选举的详细过程。