《Zookeeper》源码分析(二十)之 Follower

目录

  • Follower
    • 创建Follower实例
    • followLeader()
    • findLeader()
    • connectToLeader()
    • registerWithLeader()
    • syncWithLeader()
  • FollowerZooKeeperServer

Follower

Leader选举结束后,成为Follower的服务器开始进行Follower的工作,过程如下:
《Zookeeper》源码分析(二十)之 Follower_第1张图片

Leader的过程类似,第一步创建Follower实例,第二步开始执行工作followerLeader()

创建Follower实例

《Zookeeper》源码分析(二十)之 Follower_第2张图片

followLeader()

LeaderLearnerHandler中,当LeaderFollower建立连接后发生的工作流程如下:
《Zookeeper》源码分析(二十)之 Follower_第3张图片

在LearnerHandler的run()方法中我们已经分析了左边Leader的工作,Follower的followLeader()方法则是右边的工作,源码过程如下:
《Zookeeper》源码分析(二十)之 Follower_第4张图片

接下来具体分析第1步~第4步,第5步则会在后文具体请求时再分析。

findLeader()

《Zookeeper》源码分析(二十)之 Follower_第5张图片

connectToLeader()

《Zookeeper》源码分析(二十)之 Follower_第6张图片

在这一步中最关键的是设置了leaderIs与leaderOs,后续Follower与Leader收发信息时都直接使用这两个变量。

registerWithLeader()

当Follower与Leader成功建立连接后,Follower就开始向Leader注册自己的信息,在这个过程中包括发送身份信息、确认epoch
《Zookeeper》源码分析(二十)之 Follower_第7张图片

syncWithLeader()

当Follower与Leader确认完选举轮次epoch之后就要开始进行数据同步:

  1. 首先收到来自Leader的一个确认同步类型的包,即差异化同步DIFF、全量同步SNAP、回滚同步TRUNC
  2. 接收来自Leader的数据,即PROPOSAL,每一个PROPOSAL之后跟随一个COMMIT
  3. 数据同步结束后会收到NEWLEADER包,确认Leader
  4. Leader确认结束之后会收到UPTODATE,表明Follower已经与Leader同步,可以开始处理来自客户端的请求

源码过程如下:
《Zookeeper》源码分析(二十)之 Follower_第8张图片

Follower的初始化工作介绍到此结束。

FollowerZooKeeperServer

它的作用与LeaderLeaderZooKeeperServer类似,所以我们只介绍它定义的Processor
《Zookeeper》源码分析(二十)之 Follower_第9张图片

FollowerRequestProcessor:它的工作主要是识别出当前请求是否为事务请求,如果是事务请求,在提交给CommitProcessor后会继续将其发送给Leader进行处理。

SendAckRequestProcessor:在SyncRequestProcessor完成事务日志记录后会通过SendAckRequestProcessor向Leader发送对Proposal的反馈信息,与Leader的AckRequestProcessor本地操作不同,它是一个远程反馈。

你可能感兴趣的:(Zookeeper,zookeeper,分布式,云原生)