Zookeeper面试题

ZK节点宕机如何处理?

  1. ZK服务的机制是只要存活节点超过半数就依然可以提供服务。少于一半的话集群会失效。
  2. 如果是Follower宕机,其他Follower上是有副本的,还可以继续提供服务。
  3. 如果是Leader宕机,Zookeeper会选举出新的Leader。

ZAB协议的核心内容?

ZAB协议分为崩溃恢复消息广播

  1. 当Leader节点出现宕机,崩溃的时候,就进入崩溃恢复模式,选举产生新的Leader。
  2. 当集群中的过半机器完成状态同步(数据同步)之后就会进入到消息广播模式
  3. 这时如果一台新的机器想要加入进来,就会先自动进入恢复模式,找到Leader服务,完成数据同步,完成之后就可以成为Follower一起参与到消息广播流程中。

状态切换

  1. 如果Leader宕机,重启。当集群中的Follower过半不能与Leader进行通信的时候,ZK集群会进入到崩溃恢复模式,发起新的一轮Leader选举和同步。

保证消息有序

  1. 在整个消息广播过程中,Leader会将每一个事务转换成proposal进行广播,在广播这个事务proposal之前,Leader会先为这个事务生成一个全局递增的唯一ID。称之为事务ID(zxid),由于ZAB协议保证按照严格的顺序性。因此每一个proposal都按照zxid的顺序来进行处理。

Zookeeper如何保证是如何保证事务的顺序一致性?

zookeeper采用了全局递增的事务id来标识,所有的proposal在提出的时候都会加上一个zxid,zxid是一个64位的数字,高32位是epoch(时期),用来标识Leader的周期,如果有新的Leader产生,epoch会递增,低32位用来自增计数。当新的proposal产生的时候会经历二阶段提交过程,首先会向其他server发送事务请求,当过半的server都能够执行并且执行成功的时候,那么就开始执行。

相关推荐

  1. Zookeeper面试

    2023-12-12 00:52:03       62 阅读
  2. 分布式【ZooKeeper面试

    2023-12-12 00:52:03       44 阅读
  3. Zookeeper 面试(一)

    2023-12-12 00:52:03       22 阅读
  4. Zookeeper面试合集

    2023-12-12 00:52:03       49 阅读
  5. Zookeeper相关面试及答案

    2023-12-12 00:52:03       46 阅读
  6. 大数据开发面试Zookeeper篇】

    2023-12-12 00:52:03       29 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2023-12-12 00:52:03       98 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2023-12-12 00:52:03       106 阅读
  3. 在Django里面运行非项目文件

    2023-12-12 00:52:03       87 阅读
  4. Python语言-面向对象

    2023-12-12 00:52:03       96 阅读

热门阅读

  1. 安装CAS登录服务器

    2023-12-12 00:52:03       58 阅读
  2. C++ Primer Plus第十五章笔记

    2023-12-12 00:52:03       38 阅读
  3. RK3568 CIF和ISP的关联

    2023-12-12 00:52:03       65 阅读
  4. 云计算核心技术

    2023-12-12 00:52:03       57 阅读
  5. 利用python编写简易POC脚本

    2023-12-12 00:52:03       53 阅读
  6. 在k8s中部署nfs-client-provisioner

    2023-12-12 00:52:03       52 阅读
  7. 使用boost::hana::then的示例程序

    2023-12-12 00:52:03       56 阅读
  8. 前端项目有关面试

    2023-12-12 00:52:03       64 阅读
  9. 使用Qt实现文本闪烁效果

    2023-12-12 00:52:03       63 阅读