zookeeper源码解析--观察者

概述

观察者不参与选举,观察者身份是在集群配置文件中指定的自身角色。

主干逻辑–observerLeader

1.设置自身Zab状态为DISCOVERY
2.寻找主节点
集群配置里,配置了观察者监听端口下。
集群每个投票成员,有义务在此监听端口开启监听。
供观察者与其连接,并作为主节点,与观察者进行交互。
3.与主节点建立连接。
4.向主节点注册。
注册包:
类型--OBSERVERINFO
zxid-高32位为epoch,低32为为计数。默认acceptedEpoch,计数为0。
LearnerInfo:
自己在集群的id
版本:0x10000
集群配置版本
5.读取主节点回复
情况1:类型为LEADERINFO回复包:
	类型:LEADERINFO
	zxid-得到回复zxid中epoch。
	版本:
	采用回复中epoch作为自己的acceptedEpoch。
	向主节点发回回复包。
	回复包类型:Leader.ACKEPOCH, 
	zxid:lastLoggedZxid【自身数据实体的最后zxid】 
	epoch:epochBytes【自身currentEpoch信息】
	返回zxid,由主节点回复中的epoch&序号0组合而成。
情况2:类型为NEWLEADER
	采用回复中epoch作为自己的acceptedEpoch。
	返回回复包中zxid
6.设置Zab状态为SYNCHRONIZATION
7.与主节点同步。
读取包
情况1:读取包的类型为DIFF
	设置同步模式为DIFF
	视情况设置快照是否需要标志
情况2:读取包的类型为SNAP
	设置同步模式为SNAP
	从输入流进行反向序列化从而完成快照同步
	实体数据的集群配置信息设置为自己可见版本
	设置数据实体的最后zxid【最后zxid来自包】
	设置同步快照标志为true
情况3:读取包的类型为TRUNC
	设置同步模式为TRUNC
	对数据实体按数据包的zxid进行日志截断
	设置数据实体的最后zxid【最后zxid来自包】
情况4:
	记录日志
	退出

以自身可见集群配置信息设置数据实体配置信息
创建会话追踪
循环迭代:
	读取包
	情况1:包的类型为Leader.PROPOSAL

	情况2:包的类型为Leader.COMMIT


	情况3:包的类型为Leader.INFORM

	情况4:包的类型为Leader.UPTODATE

	情况5:包的类型为Leader.NEWLEADER

情况4:
上一篇:【Kafka中文社区】Kafka核心组件之Controller选举机制(3)


下一篇:C# 各类文件扩展名