当前位置: 首页 > news >正文

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

目录

    • 一、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.lryc.cn/news/28465.html

相关文章:

  • Python | Leetcode刷题日寄Part05
  • SpringCloud学习笔记(一)
  • 【C语言指针练习题】你真的学会指针了吗?
  • java实现UDP及TCP通信
  • 深度学习-第T1周——实现mnist手写数字识别
  • 质量保障(QA)和质量控制(QC)
  • 你真的会用三元运算符吗?
  • TIA博途中使用SCL语言实现选择排序算法并封装成FC全局库
  • 【C++修炼之路】24.哈希应用--位图
  • 4. 字符设备驱动高级--- 下篇
  • ChatGPT介绍以及一些使用案例
  • PCL 点云高斯混合聚类(GMM)
  • Docker学习(十六)踩坑,如何将对容器的修改同步到基础镜像中
  • 食品与疾病关系预测赛题
  • Symbol
  • NC65 对上年度反结账,调整数据后重新结账后,对本年度年初重算时系统报错:更新记数错误。
  • 位运算相关
  • Linux进程信号(产生、保存、处理)/可重入函数概念/volatile理解/SIGCHLD信号
  • 锯齿数组 - 贪心
  • [CVPR 2022] Balanced Contrastive Learning for Long-Tailed Visual Recognition
  • 23种设计模式-工厂模式
  • Linux操作系统学习(进程等待)
  • Docker学习(十八)load 和 import 命令的区别
  • mysql中的事务
  • 《C++ Primer Plus》第18章:探讨 C++ 新标准(9)
  • 记录一次PWM信号异常问题
  • 简单了解---性能测试
  • 1.机器学习笔记第一周
  • 若依学习(前后端分离版)——启动时发生了啥?(@PostConstruct)(mybatis log free)
  • 每日十问9c++-内存模型和名称空间