news 2025/12/31 14:25:04

ZooKeeper选举机制详解

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
ZooKeeper选举机制详解

Zookeeper选举机制——第一次启动

SID:服务器ID。用来唯一标识一台ZooKeeper集群中的机器,每台机器不能重复,和myid一致。
ZXID:事务ID。ZXID是一个事务ID,用来标识一次服务器状态的变更。在某一时刻,集群中的每台机器的ZXID值不一定完全一致,这和ZooKeeper服务器对于客户端“更新请求”的处理逻辑有关。
Epoch:每个Leader任期的代号。没有Leader时同一轮投票过程中的逻辑时钟值是相同的。每投完一次票这个数据就会增加。

(1)服务器1启动,发起一次选举。服务器1投自己一票。此时服务器1票数一票,不够半数以上(3票),选举无法完成,服务器1状态保持为LOOKING;
(2)服务器2启动,再发起一次选举。服务器1和2分别投自己一票并交换选票信息:此时服务器1发现服务器2的myid比自己目前投票推举的(服务器1)大,更改选票为推举服务器2。此时服务器1票数0票,服务器2票数2票,没有半数以上结果,选举无法完成,服务器1,2状态保持LOOKING
(3)服务器3启动,发起一次选举。此时服务器1和2都会更改选票为服务器3。此次投票结果:服务器1为0票,服务器2为0票,服务器3为3票。此时服务器3的票数已经超过半数,服务器3当选Leader。服务器1,2更改状态为FOLLOWING,服务器3更改状态为LEADING;
(4)服务器4启动,发起一次选举。此时服务器1,2,3已经不是LOOKING状态,不会更改选票信息。交换选票信息结果:服务器3为3票,服务器4为1票。此时服务器4服从多数,更改选票信息为服务器3,并更改状态为FOLLOWING;
(5)服务器5启动,同4一样当小弟。

Zookeeper选举机制——非第一次启动

SID:服务器ID。用来唯一标识一台ZooKeeper集群中的机器,每台机器不能重复,和myid一致。
ZXID:事务ID。ZXID是一个事务ID,用来标识一次服务器状态的变更。在某一时刻,集群中的每台机器的ZXID值不一定完全一致,这和ZooKeeper服务器对于客户端“更新请求”的处理逻辑有关。
Epoch:每个Leader任期的代号。没有Leader时同一轮投票过程中的逻辑时钟值是相同的。每投完一次票这个数据就会增加。

(1)当ZooKeeper集群中的一台服务器出现以下两种情况之一时,就会开始进入Leader选举:

• 服务器初始化启动。
• 服务器运行期间无法和Leader保持连接。

(2)而当一台机器进入Leader选举流程时,当前集群也可能会处于以下两种状态:
• 集群中本来就已经存在一个Leader。
对于第一种已经存在Leader的情况,机器试图去选举Leader时,会被告知当前服务器的Leader信息,对于该机器来说,仅仅需要和Leader机器建立连接,并进行状态同步即可。
• 集群中确实不存在Leader。
假设ZooKeeper由5台服务器组成,SID分别为1、2、3、4、5,ZXID分别为8、8、8、7、7,并且此时SID为3的服务器是Leader。某一时刻,3和5服务器出现故障,因此开始进行Leader选举。
(EPOCH,ZXID,SID )(EPOCH,ZXID,SID ) (EPOCH,ZXID,SID )
SID为1、2、4的机器投票情况: (1,8,1) (1,8,2) (1,7,4)

选举Leader规则:

①EPOCH大的直接胜出

②EPOCH相同,事务id大的胜出

③事务id相同,服务器id大的胜出

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2025/12/12 11:37:02

图片GPS数据编辑器 - 在线编辑图片GPS地理信息位置信息

软件介绍 图片GPS数据编辑器是一款功能强大的在线工具,专为编辑图片GPS位置信息而设计。该工具支持添加、修改和删除图片的GPS数据,所有操作均在本地完成,无需上传图片到服务器,最大程度保护用户隐私。 功能特点 🎯…

作者头像 李华
网站建设 2025/12/25 8:15:00

光特通信:硬核技术背后的隐形冠军

在万物互联的时代,光纤通信如同信息高速公路的"基石",而光模块则是这条公路上精准指挥的"智能信号灯"。作为国内少数具备从自主研发到销售全产业链能力的企业,深圳市光特通信技术有限公司正以自主创新的技术实力&#xf…

作者头像 李华
网站建设 2025/12/31 3:18:52

MATLAB图像导出完整指南:从基础到专业的完美解决方案

MATLAB图像导出完整指南:从基础到专业的完美解决方案 【免费下载链接】export_fig A MATLAB toolbox for exporting publication quality figures 项目地址: https://gitcode.com/gh_mirrors/ex/export_fig 还在为MATLAB导出的图像质量不佳而烦恼吗&#xff…

作者头像 李华
网站建设 2025/12/27 17:46:08

YimMenu完整使用指南:GTA5游戏修改工具详解

项目概述 【免费下载链接】YimMenu YimMenu, a GTA V menu protecting against a wide ranges of the public crashes and improving the overall experience. 项目地址: https://gitcode.com/GitHub_Trending/yi/YimMenu YimMenu是一款专为《侠盗猎车手5》(…

作者头像 李华
网站建设 2025/12/12 11:35:25

三级防护+119种语言:Qwen3Guard-Gen-4B重塑AI内容安全标准

三级防护119种语言:Qwen3Guard-Gen-4B重塑AI内容安全标准 【免费下载链接】Qwen3Guard-Gen-4B 项目地址: https://ai.gitcode.com/hf_mirrors/Qwen/Qwen3Guard-Gen-4B 导语 阿里通义千问团队推出的Qwen3Guard-Gen-4B安全模型,以三级风险分类体系…

作者头像 李华
网站建设 2025/12/22 22:18:19

数据挖掘学习革命:韩家炜第四版PPT课件完整指南

数据挖掘学习革命:韩家炜第四版PPT课件完整指南 【免费下载链接】数据挖掘概念与技术韩家炜第四版PPT课件全 《数据挖掘:概念与技术》韩家炜第四版 PPT 课件,完整覆盖原书12章内容,专为数据挖掘学习者设计。课件基于2022年最新版教…

作者头像 李华