《Zookeeper》源码分析(十九)之 LearnerHandler

LearnerCnxAcceptor

Leader.lead()方法中创建并启动LearnerCnxAcceptor线程,该线程主要是建立LearnerCnxAcceptorHandler并将其放入线程池中等待执行,每一个LearnerCnxAcceptorHandler代表Leader服务器的一个服务器地址监听器。

run()

在这里插入图片描述

LearnerCnxAcceptorHandler

LearnerCnxAcceptorHandler监听来自集群中Learner服务器的连接,每监听到一个连接就创建一个LearnerHandler实例并将其启动。

run()

在这里插入图片描述

LearnerHandler

它是服务器的管理器,主要负责Follower/Observer服务器与Leader服务器之间的一系列网络通信,包括数据同步、请求转发和Proposal提议的投票等,它的工作流程如下:
在这里插入图片描述

run()

LearnerHandler的工作如下:
在这里插入图片描述

第1步至第16步都是在进行初始化工作,当这16步都结束后就进入leader与learner之间的发送请求与处理请求的过程,第17步在后文针对具体的请求再做详细的分析,接下来着重分析第9步中的syncFollower()、第10步、第12步中的startSendingPackets()。

syncFollower()

  1. 在开始数据同步之前,会收集leader服务器提议缓存队列中的最小ZXID和最大ZXID,以及learner服务器最后处理的ZXID
  2. 如果leader与learner最后一次处理的zxid相等,则只需要发送DIFF包
  3. 如果peeLastZxid大于maxCommittedLog,leader会发送TRUNC包要求learner回滚到zxid值为maxCommitedLog对应的事务操作
  4. 如果peeLastZxid介于maxCommittedLogminCommitedLog两者之间,则leader向learner发送(peeLastZxid, maxCommittedLog]之间的数据包进行同步
  5. 如果peeLastZxid小于minCommitedLog,则先发送事务日志获取所缺的数据,再发送内存数据库中的数据进行同步。如果事务日志中数据依旧不足,则需要从快照日志中进行全量同步
  6. 最后,将Leader中待提交的数据发送给learner
    在这里插入图片描述

SNAP全量同步

在这里插入图片描述

startSendingPackets()

在这里插入图片描述

至此,LeaderLearner的通信网络介绍到此结束。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值