一文带你看透Zookeeper中的ZAB协议!

2024-01-28 08:58

本文主要是介绍一文带你看透Zookeeper中的ZAB协议!,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

前言

ZAB 协议是为分布式协调服务ZooKeeper专门设计的一种支持崩溃恢复的一致性协议。基于该协议,ZooKeeper 实现了一种主从模式的系统架构来保持集群中各个副本之间的数据一致性。今天主要看看这个zab协议的工作原理。

Java中间件面试真题 +学习笔记

一、什么是ZAB协议

话说在分布式系统中一般都要使用主从系统架构模型,指的是一台leader服务器负责外部客户端的写请求。然后其他的都是follower服务器负责读。leader服务器将客户端的写操作数据同步到所有的follower节点中。

就这样,客户端发送来的写请求,全部给Leader,然后leader再转给Follower。这时候需要解决两个问题:

(1)leader服务器是如何把数据更新到所有的Follower的。

(2)Leader服务器突然间失效了,怎么办?

因此ZAB协议为了解决上面两个问题,设计了两种模式:

(1)消息广播模式:把数据更新到所有的Follower

(2)崩溃恢复模式:Leader发生崩溃时,如何恢复

OK。现在带着这两个问题,我们来详细的看一下:

二、ZAB协议工作原理

1、消息广播模式:

如果你了解过2PC协议的话,理解起来就简单很多了,消息广播的过程实际上是一个简化版本的二阶段提交过程。我们来看一下这个过程:

(1)Leader将客户端的request转化成一个Proposal(提议)

(2)Leader为每一个Follower准备了一个FIFO队列,并把Proposal发送到队列上。‘

(3)leader若收到follower的半数以上ACK反馈

(4)Leader向所有的follower发送commit。

其实通俗的理解就比较简单了,我是领导,我要向各位传达指令,不过传达之前我先问一下大家支不支持我,若有一半以上的人支持我,那我就向各位传达指令了。

(1)leader首先把proposal发送到FIFO队列里

(2)FIFO取出队头proposal给Follower

(3)Follower反馈一个ACK给队列

(4)队列把ACK交给leader

(5)leader收到半数以上ACK,就会发送commit指令给FIFO队列

(6)FIFO队列把commit给Follower。

这就是整个消息广播模式。下面我们开始看一下,如果这个leader节点崩溃了,怎么办?也就是第二种模式:崩溃回复模式。

2、崩溃恢复模式

leader就是一个领导,既然领导挂了,整个组织肯定不会散架,毕竟离开谁都能活下去是不是,这时候我们只需要选举一个新的领导即可,而且还要把前leader还未完成的工作做完,也就是说不仅要进行leader服务器选取,而且还要进行崩溃恢复。我们一个一个来解决。

(1)leader服务器选取

话说江湖上有一个神秘组织,这个组织分工明确,各司其职,平时这个组织的成员有三种状态:

looking状态:也就是观望状态,这时候是由于组织出现内部问题,那就停下来,做一些其他的事。

following状态:自身是一个组织成员,做自己的事。

leading状态:自身是一个组织老大,做自己的事。

但是这个组织只有一个老大。突然有一天,老大挂掉了,于是每一个成员的状态变成了looking状态。于是成员宣布要选举新的leader。

既然是选老大,每个人都想做,于是成员ABC开始了公平选举的过程。但是为了方便,每个人都有一个记录表,来记录当前的信息。

第一步:成员A告诉BC说我要成为老大,BC记录下来。(A成员广播)

第二步:B回复可以,C回复不可以。(B成员广播)

第三步:A和C收到B的消息,更新自己的记录表。

此时A:2票,B:0票,C:0票。

第四步:C这时候不满意了,也要选举成为老大。而且还给自己投了一票。

第五步:A回复可以,B回复可以。更新自己的记录表。

第六步:C收到AB的回复,更新。

此时A:0票,B:0,C:3票。于是确定C就是下一届组织老大了。

这就是整个选举的过程。并且每个人的选举,都代表了一个事件,为了保证分布式系统的时间有序性,因此给每一个事件都分配了一个Zxid。相当于编了一个号。低32位是按照数字递增,即每次客户端发起一个proposal,低32位的数字简单加1。高32位是leader周期的epoch编号。

每当选举出一个新的leader时,新的leader就从本地事物日志中取出ZXID,然后解析出高32位的epoch编号,进行加1,再将低32位的全部设置为0。这样就保证了每次新选举的leader后,保证了ZXID的唯一性而且是保证递增的。

OK,老大选举完了,这时候前老大遗留下来的事还没完成呢,此时就要开始恢复了。

(2)崩溃恢复

既然要恢复,有些场景是不能恢复的,ZAB协议崩溃恢复要求满足如下2个要求: 第一: 确保已经被leader提交的proposal必须最终被所有的follower服务器提交。 第二:确保丢弃已经被leader出的但是没有被提交的proposal。

好了,现在开始进行恢复。

第一步:选取当前取出最大的ZXID,代表当前的事件是最新的。

第二步:新leader把这个事件proposal提交给其他的follower节点

第三步:follower节点会根据leader的消息进行回退或者是数据同步操作。最终目的要保证集群中所有节点的数据副本保持一致。

这就是整个恢复的过程,其实就是相当于有个日志一样的东西,记录每一次操作,然后把出事前的最新操作恢复,然后进行同步即可。

OK。这个就是ZAB协议的整个过程。

原文链接:https://www.toutiao.com/i6825840939433476616/?

这篇关于一文带你看透Zookeeper中的ZAB协议!的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/653126

相关文章

Java使用Curator进行ZooKeeper操作的详细教程

《Java使用Curator进行ZooKeeper操作的详细教程》ApacheCurator是一个基于ZooKeeper的Java客户端库,它极大地简化了使用ZooKeeper的开发工作,在分布式系统... 目录1、简述2、核心功能2.1 CuratorFramework2.2 Recipes3、示例实践3

一文详解SpringBoot响应压缩功能的配置与优化

《一文详解SpringBoot响应压缩功能的配置与优化》SpringBoot的响应压缩功能基于智能协商机制,需同时满足很多条件,本文主要为大家详细介绍了SpringBoot响应压缩功能的配置与优化,需... 目录一、核心工作机制1.1 自动协商触发条件1.2 压缩处理流程二、配置方案详解2.1 基础YAML

一文详解如何从零构建Spring Boot Starter并实现整合

《一文详解如何从零构建SpringBootStarter并实现整合》SpringBoot是一个开源的Java基础框架,用于创建独立、生产级的基于Spring框架的应用程序,:本文主要介绍如何从... 目录一、Spring Boot Starter的核心价值二、Starter项目创建全流程2.1 项目初始化(

一文带你了解SpringBoot中启动参数的各种用法

《一文带你了解SpringBoot中启动参数的各种用法》在使用SpringBoot开发应用时,我们通常需要根据不同的环境或特定需求调整启动参数,那么,SpringBoot提供了哪些方式来配置这些启动参... 目录一、启动参数的常见传递方式二、通过命令行参数传递启动参数三、使用 application.pro

一文带你深入了解Python中的GeneratorExit异常处理

《一文带你深入了解Python中的GeneratorExit异常处理》GeneratorExit是Python内置的异常,当生成器或协程被强制关闭时,Python解释器会向其发送这个异常,下面我们来看... 目录GeneratorExit:协程世界的死亡通知书什么是GeneratorExit实际中的问题案例

一文详解SQL Server如何跟踪自动统计信息更新

《一文详解SQLServer如何跟踪自动统计信息更新》SQLServer数据库中,我们都清楚统计信息对于优化器来说非常重要,所以本文就来和大家简单聊一聊SQLServer如何跟踪自动统计信息更新吧... SQL Server数据库中,我们都清楚统计信息对于优化器来说非常重要。一般情况下,我们会开启"自动更新

一文详解kafka开启kerberos认证的完整步骤

《一文详解kafka开启kerberos认证的完整步骤》这篇文章主要为大家详细介绍了kafka开启kerberos认证的完整步骤,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录一、kerberos安装部署二、准备机器三、Kerberos Server 安装1、配置krb5.con

一文详解Nginx的强缓存和协商缓存

《一文详解Nginx的强缓存和协商缓存》这篇文章主要为大家详细介绍了Nginx中强缓存和协商缓存的相关知识,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录一、强缓存(Strong Cache)1. 定义2. 响应头3. Nginx 配置示例4. 行为5. 适用场景二、协商缓存(协

一文详解如何在Python中使用Requests库

《一文详解如何在Python中使用Requests库》:本文主要介绍如何在Python中使用Requests库的相关资料,Requests库是Python中常用的第三方库,用于简化HTTP请求的发... 目录前言1. 安装Requests库2. 发起GET请求3. 发送带有查询参数的GET请求4. 发起PO

Qt 中集成mqtt协议的使用方法

《Qt中集成mqtt协议的使用方法》文章介绍了如何在工程中引入qmqtt库,并通过声明一个单例类来暴露订阅到的主题数据,本文通过实例代码给大家介绍的非常详细,感兴趣的朋友一起看看吧... 目录一,引入qmqtt 库二,使用一,引入qmqtt 库我是将整个头文件/源文件都添加到了工程中进行编译,这样 跨平台