Zookeeper3.5.7版本——选举机制(非第一次启动)

news/2024/10/22 18:17:40/

目录

    • 一、ZooKeeper集群中哪些情况会进入Leader选举
    • 二、当一台机器进入Leader选举流程时,当前集群的两种状态
      • 2.1、集群中本来就已经存在一个Leader
      • 2.2、集群中确实不存在Leader
    • 三、Zookeeper中的一些概念了解
      • 3.1、SID
      • 3.2、ZXID
      • 3.3、Epoch

一、ZooKeeper集群中哪些情况会进入Leader选举

  • ZooKeeper集群服务器初始化启动时,进入Leader选举。
    在这里插入图片描述

  • ZooKeeper集群服务器运行期间无法和Leader保持连接时,进入Leader选举。例如:下图中服务器5挂掉之后,无法与Leader保持连接时。
    在这里插入图片描述

二、当一台机器进入Leader选举流程时,当前集群的两种状态

2.1、集群中本来就已经存在一个Leader

  • 对于已经存在Leader的情况,机器试图去选举Leader时,会被告知当前服务器的Leader信息,对于该机器(即服务器5)来说,仅仅需要和Leader机器建立连接,并进行状态同步即可。
    在这里插入图片描述

2.2、集群中确实不存在Leader

  • 假设ZooKeeper由5台服务器组成,SID分别为1、2、3、4、5,ZXID分别为8、8、8、7、7,并且此时SID为3的服务器是Leader。某一时刻,3和5服务器出现故障,因此开始进行Leader选举。
    在这里插入图片描述

  • SID为1、2、4的机器投票情况

    服务器EPOCHZXIDSID
    服务器1181
    服务器2182
    服务器3174
  • 选举Leader规则

    ①EPOCH(即每个Leader任期的代号)大的直接胜出

    ②EPOCH相同,事务id(即ZXID)大的胜出

    ③事务id相同,服务器id(即SID)大的胜出

三、Zookeeper中的一些概念了解

3.1、SID

  • SID服务器ID。用来唯一标识一台ZooKeeper集群中的机器,每台机器不能重复,和myid一致

3.2、ZXID

  • ZXID事务ID。用来标识一次服务器状态的变更。在某一时刻,集群中的每台机器的ZXID值不一定完全一致,这和ZooKeeper服务器对于客户端“更新请求”的处理逻辑有关。
    在这里插入图片描述

3.3、Epoch

  • Epoch每个Leader任期的代号。没有Leader时同一轮投票过程中的逻辑时钟值是相同的。每投完一次票这个数据就会增加

http://www.ppmy.cn/news/29927.html

相关文章

【Python】使用Playwright断言方法验证网页和Web应用程序状态

作为测试框架,Playwright 提供了一系列断言方法,您可以使用它们来验证网页和 Web 应用程序的状态。在这篇博客中,田辛老师将介绍 Playwright 中可用的各种断言方法,并为每种方法提供示例。 assert page.url() expected_url &…

WSL2使用Nvidia-Docker实现深度学习环境自由部署

1. Win11 显卡驱动的安装 注意:WSL2中是不需要且不能安装任何显卡驱动的,它的显卡驱动完全依赖于 Win11 中的显卡驱动,因此我们只需要安装你显卡对应的 Win11 版本显卡驱动版本(必须是 Win11 版本的驱动),…

phpinfo包含临时文件Getshell全过程及源码

目录 前言 原理 漏洞复现 靶场环境 源码 复现过程 前言 PHP LFI本地文件包含漏洞主要是包含本地服务器上存储的一些文件,例如session文件、日志文件、临时文件等。但是,只有我们能够控制包含的文件存储我们的恶意代码才能拿到服务器权限。假如在服…

湖州银行冲刺A股上市:计划募资约24亿元,资产质量水平较高

3月4日,湖州银行股份有限公司(下称“湖州银行”)递交招股书,准备在上海证券交易所主板上市。本次冲刺上市,湖州银行计划募资23.98亿元,将在扣除发行费用后全部用于补充该行资本金。 湖州银行在招股书中表示…

备战四级!!!

目录 一、替换词 二、作文常见句型 (1)常见开头 (2)阐述观点 (3)结束语 (4)提出建议 (5)表示论证 (6)给出原因 (…

CANFDNET-200U-UDP配置与数据收发控制

一、启动ZCANPRP,打开设备管理页面,选择类型CANFDNET-200U-UDP,如图1 图1 二、打开设备,启动,在相应页面如图2,配置协议,CANFD 加速,本地端口,IP地址,工作端口。 图2 三、发送相应数…

Python基础知识——字符串、字典

字符串 在Python中,字符和字符串没有区别。可能有些同学学过其他的语言,例如Java,在Java中,单引号’a’表示字符’a’,双引号"abc"表示字符串"abc",但在Python当中,它们没…

elisp简单实例: auto-save

elisp 能找一个简单又实用的代码很不容易,以下代码不是我的原创,只是结合自己的理解,添加修正了一些注释,荣誉归原作者,感谢原作者的开源精神! 调用说明: 把后面代码存为auto-save.el 在init.el 中写上 (require auto-save) 就可以了. 下面是auto-save.el 内容了. ;; 我…