温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

ZAB协议的原理是什么

发布时间:2021-12-09 15:22:50 来源:亿速云 阅读:421 作者:柒染 栏目:大数据

今天就跟大家聊聊有关ZAB协议的原理是什么,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。

ZAB协议是为分布式协调服务Zookeeper专门设计的一种支持崩溃恢复的原子广播协议。在Zookeeper中,主要依赖ZAB协议来实现分布式数据一致性。

ZAB协议内容

ZAB协议主要有两种模式:崩溃恢复和消息广播。

服务器启动、或者Leader宕机、或者Leader与绝大多数Follower无法正常通信时,ZAB协议就会进入崩溃恢复模式用来产生新的Leader。

当选举产生新的Leader并且完成数据同步以后,ZAB协议将由崩溃恢复模式转变为消息广播模式。

在ZAB协议的设计中,每一个进程都可能处于下面三种状态中的一种:

  • LOOKING:Leader选举阶段

  • FOLLOWING:Follower服务器和Leader保持同步状态

  • LEADING:Leader服务器作为主进程领导状态

ZAB协议需要保证以下两条原则:

  • 确保那些已经在Leader服务器上提交的事务最终被所有的服务器进行提交(在Leader上提交,说明绝大多数Follower已经接收到了事务的Proposal请求并返回了ACK响应,只是还未收到commit请求)

  • 确保丢弃那些只在Leader服务器上被提出的事务(只在Leader上被提出说明没有其他Follower并没有收到Proposal请求)

消息广播

消息广播模式是在整个集群稳定运行时的模式。它的操作类似于两阶段提交。

在消息的广播过程中,Leader会为每一个Follower准备一个事务队列,该队列符合FIFO原则。假设Follower接收到了客户端的写请求,写请求会被转发至Leader处理,当Leader收到客户端的写请求时,主要有以下步骤:

  1. 为写请求的事务Proposal分配一个全局唯一递增的ID(ZXID)

  2. 将这个事务放入每个Follower对应的事务队列,并按照FIFO顺序进行广播

  3. Follower接收到事务请求后,将该事务请求写入本地事务日志文件,并在写成功后给Leader返回ACK响应

  4. 当Leader收到过半的Follower返回的ACK,便向所有的Follower发送commit请求通知Follower执行事务提交,同时Leader自身也完成事务提交

  5. Follower收到commit请求后,完成事务提交

Leader为每个Follower使用队列做了异步解耦,大大降低同步阻塞,提高了系统的吞吐量。

崩溃恢复

崩溃恢复主要用来当Leader宕机或者Leader与大多数Follower因为网络原因无法通信时进行新Leader的选举或者集群启动时进行Leader的选举。崩溃恢复主要由两个过程组成:Leader选举、数据同步。

Leader选举

保证上述原则实现Leader很简单,只要保证新选出来的Leader服务器拥有最大的ZXID就可以,那么这个新Leader一定具有所有已提交的事务,还可以省去检查Proposal的提交和丢弃工作。

首先确认一个点,每个Zookeeper节点进入LOOKING状态时,都会发起选举流程,其他的Zookeeper机器收到该请求时,只有两种响应:

  • 接收选票提议,同意Zookeeper节点成为Leader候选人

  • 否决选票提议,并推荐自己上一次推荐的服务器作为Leader候选人

其次我们来讲述一下ZXID这个概念,ZXID其实就是一个全局单调递增的唯一的事务ID,由高32位的epoch表示选举周期和低32位的自增事务ID组成,每经历一次选举产生新的Leader,epoch的值将加1,而且低32位的的ID将被置为0,重新从0开始自增。

下面简单描述一下准Leader选举的过程,后面会出一篇源码分析来详解Leader的选举:

  1. 首先参与Leader选举的服务器必须是状态位LOOKING状态的节点

  2. Zookeeper节点向其他的服务器节点发送自己要成为Leader候选人的请求(请求包含ZXID)

  3. 其他节点收到请求后,将本地事务日志的ZXID与请求中ZXID进行比较,如果发现比自己的大(如果ZXID一样大就比较myid(这个后面讲)),就同意该节点成为候选人并更新 该节点为推荐候选人而不是自己然后通知其他的节点,否则还是将自己作为候选人推荐

  4. 每次投票都会进行统计,判断是否有过半的服务器收到的推荐候选人是一致的,如果过半就认为已经选出了准Leader

  5. 一旦选举完成,就需要改变服务状态,新的Leader置为LEADING状态,其他机器转变为FOLLOWING状态

数据同步

只有当集群中的过半及其完成了数据同步,准Leader就可以真正的成为Leader。Follower只会接收ZXID比自己的最后一次事务的ZXID大的提议。

  1. 所有的Follower向准Leader发送自己的最后接收事务的epoch

  2. 准Leader选出最大的epoch,并在此基础上进行加1,然后将新的epoch发送给所有的Follower

  3. Follower收到新的epoch之后,与自己的进行比较,小于就将自己的epoch更新成新的epoch,并向准Leader反馈ACK信息(epoch、历史事务集合)

  4. 准Leader收到ACK消息后,会在所有历史事务集合中选出其中一个历史事务集合作为初始化历史事务集合,该事务集合必须满足最大ZXID

  5. 准Leader将epoch和初始化历史事务集合发送给过半的Follower,每个Follower分配一个事务队列然后逐条将事务发送给Follower

  6. Follower接收到事务请求后,如果已执行过则跳过,未执行则执行事务并反馈响应给准Leader

  7. 准Leader收到响应后则发起事务commit请求,提交事务

  8. 数据完成同步后,准Leader就是Leader,ZAB协议由崩溃恢复模式进入消息广播模式

ZAB和Paxos区别

本质区别在于设计的目的不一样,ZAB协议主要使用来构建一个高可用的分布式数据主备系统,Paxos算法主要是用来解决数据一致性。

看完上述内容,你们对ZAB协议的原理是什么有进一步的了解吗?如果还想了解更多知识或者相关内容,请关注亿速云行业资讯频道,感谢大家的支持。

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

zab
AI