ZK数据同步
整个集群完成Learner选举后,Learner向Leader发起注册,然后进入数据同步环节,即Leader将learner上缺失的事务请求同步给Learner
1). 获取Learner状态 根据Learner发送的ACKEPOCH,leader解析出该learner的currentEpoch和lastZxid
2). leader进行自身数据同步初始化,包括peerLastZxid/minCommmittedLog/maxCommittedLog
3). 根据情况Leader发送 DIFF或TRUNC或SNAP 通知learner准备开始同步同步消息
4). Leader发送差异化数据
5). leader继续发送一个NEWLEADER指令表明数据发送完成
6). Leaner接收处理数据完成后,就发送ACK消息
7). Leader收到ACK就认为该节点已同步完成,并进入"过半策略"等待
8). leader广播一个UPTODATE消息通知 已有过半机器完成数据同步,可以对外提供服务了
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步