一、Zookeeper角色的分类

  1. 领导者(leader)
    Leader服务器为客户端提供读服务和写服务。

  2. 学习者(learner)
    • 跟随者(follower)
      Follower服务器为客户端提供读服务,参与Leader选举过程,参与写操作“过半写成功”策略。
    • 观察者(observer)
      Observer服务器为客户端提供读服务,不参与Leader选举过程,不参与写操作“过半写成功”策略。用于在不影响写性能的前提下提升集群的读性能。
  3. 客户端(client)
    服务请求发起方。

Zookeeper集群管理图:

二、Zookeeper角色的状态

  1. LOOKING:
       当前Server未知集群中的Leader,并且正在寻找。
  2. LEADING:
       当前Server即为选举出来的Leader。
  3. FOLLOWING:
       当前Follower已与选举出来的Leader同步。
  4. OBSERVING
      当前Observer已与选举出来的Leader同步。

三、Zookeeper各角色的作用

3.1、Zookeeper中的请求

  • 事务请求:
     在Zookeeper中,会改变服务器状态的请求称为事务请求(包括:创建节点、更新数据、删除节点、创建会话等) 。
  • 非事务请求
     从Zookeeper仅仅读取数据,不会对服务器数据状态进行任何修改的请求称为非事务请求。

3.2、Leader的作用

  1. 在ZAB崩溃恢复之后,消息广播之前,进行集群中的数据同步;
  2. 维持与Learner的心跳,接收Learner请求消息,并据不同的消息类型,进行不同的处理;
  3. Learner处理的消息类型包括:PING消息、REQUEST消息、ACK消息、REVALIDATE消息等。

  其中,PING消息指Learner的心跳信息;REQUEST消息是Follower发送的提议信息,包括写请求及同步请求;ACK消息是Follower的对提议的回复,超过半数的Follower通过,则commit该提议;REVALIDATE消息是用来延长SESSION有效时间。
Leader的工作流程简图如下所示,实际上流程要比下图复杂得多,启动了三个线程来实现功能:

3.3、Follower的作用

Follower主要有四个功能:

  1. 向Leader发送请求(PING请求、REQUEST消息、ACK请求、REVALIDATE消息);
  2. 接收Leader 的消息并进行处理;
  3. 接收Client的请求,如果为写请求,发送给Leader进行投票;
  4. 返回Client请求结果。

Follower的消息循环处理以下来自Leader的消息:

  1. PING消息:心跳消息;
  2. PROPOSAL消息:Leader发起的提案,要求Follower投票;
  3. COMMIT消息:服务器端最新一提案的信息;
  4. UPTODATE消息:表示同步完成;
  5. REVALIDATE消息:根据Leader的REVALIDATE结果,关闭待revalidate的session还是允许其接受消息;
  6. SYNC消息:返回SYNC结果到客户端,这个消息最初由客户端发起,用来强制得到最新的数据更新。

3.3、Observer的作用

  Observer角色除了不参与Leader选举和Proposal投票外,与Follower的作用相同。

四、参考资料

参考书籍:从Paxos到Zookeeper:分布式一致性原理与实践
参考博客:https://blog.csdn.net/yu757371316/article/details/80742223

  • 作者:
    DeepInThought


    出处:
    https://www.cnblogs.com/DeepInThought


    本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。
  • 【3】Zookeeper中的角色的更多相关文章

    1. zookeeper中Watcher和Notifications

      问题导读:1.zookeeper观察者什么时候调用?2.传统远程轮询服务存在什么问题?3.zk中回调服务的机制是什么?4.zk中watcher为什么不永久注册?5.什么是znode? 在阅读之前首先明 ...

    2. Apache ZooKeeper在Kafka中的角色 - 监控和配置

      1.目标 今天,我们将看到Zookeeper在Kafka中的角色.本文包含Kafka中需要ZooKeeper的原因.我们可以说,ZooKeeper是Apache Kafka不可分割的一部分.在了解Zo ...

    3. 【分布式】Zookeeper的服务器角色

      一.前言 前一篇已经详细的讲解了Zookeeper的Leader选举过程,下面接着学习Zookeeper中服务器的各个角色及其细节. 二.服务器角色 2.1 Leader Leader服务器是Zook ...

    4. Zookeeper中Session Timeout的那些事

      前言: RDS系统致力于MySQL数据的高可用,高可靠,高性能以及在线扩展功能,实现这些特性的主要逻辑功能都运行在管理服务器上,一旦管理服务器宕机,数据库的在线扩展功能/备份功能/故障恢复功能等都无从 ...

    5. zookeeper中的分布式一致性协议

      1. zookeeper中的一致性协议-ZAB协议 在深入了解ZK之前,相信很多同学都会认为ZK就是Paxos算法的一个实现.但事实上,ZK并没有完全采用Paxos算法,而是使用了一种称为ZooKee ...

    6. Zookeeper中的watcher监听和leader选举机制

      watcher监听 什么是watcher接口 同一个事件类型在不同的通知状态中代表的含义有所不同,下图列举了常见的通知状态和事件类型. Watcher通知状态与事件类型一览 上图列举了ZooKeepe ...

    7. Zookeeper中的Leader选取机制

      一.Zookeeper是什么? ZooKeeper是一个分布式的,开放源码的分布式应用程序协调服务,是Google的Chubby一个开源的实现,是Hadoop和Hbase的重要组件.它是一个为分布式应 ...

    8. 面试官:说一说Zookeeper中Leader选举机制

      哈喽!大家好,我是小奇,一位不靠谱的程序员 小奇打算以轻松幽默的对话方式来分享一些技术,如果你觉得通过小奇的文章学到了东西,那就给小奇一个赞吧 文章持续更新 一.前言 今天又是一个阳光明媚的一天,我又 ...

    9. Twitter Storm源代码分析之ZooKeeper中的目录结构

      徐明明博客:Twitter Storm源代码分析之ZooKeeper中的目录结构 我们知道Twitter Storm的所有的状态信息都是保存在Zookeeper里面,nimbus通过在zookeepe ...

    随机推荐

    1. CentOS 7系统配置上的变化

      http://www.linuxidc.com/Linux/2014-09/107375p4.htm CentOS 7系统配置上的变化解析 ip ss指令替代 ifconfig route arp n ...

    2. 部署Hadoop-3.0-高性能集群

      一.Hadoop概述: Hadoop是一个由Apache基金会所开发的分布式系统基础架构.用户可以在不了解分布式底层细节的情况下,开发分布式程序.充分利用集群的威力进行高速运算和存储.Hadoop的框 ...

    3. 数据分析电子商务B2C全流程_数据分析师

      数据分析电子商务B2C全流程_数据分析师 目前,绝大多数B2C的转化率都在1%以下,做的最好的也只能到3.5%左右(比如以卖图书为主的当当) 我想,所有的B2C都会关心三个问题:究竟那97%去了哪里? ...

    4. The working copy is locked due to a previous error.

      SVN报错: The working copy is locked due to a previous error. 不能更新项目代码... 解决方式: 解决:右键你的左侧管理目录中的相关目录,然后点 ...

    5. Java内部类(4):静态内部类&接口内部类

      使用static修饰的内部类我们称之为静态内部类,不过我们更喜欢称之为嵌套内部类.静态内部类与非静态内部类之间存在一个最大的区别,我们知道非静态内部类在编译完成之后会隐含地保存着一个引用,该引用是指向 ...

    6. 【笔记】《CNCF × Alibaba云原生技术公开课》知识点

      一,课时1:第一堂“云原生”课 二,课时2:容器基本概念 1.已运行 docker run -d -t —name demo ubuntu top 命令, 是否可以在 demo 这个容器内部停止容器? ...

    7. ubuntu下不能访问docker中的rabbitmq服务端口

      主要原因是防火墙屏蔽了15672端口,宿主机就不能直接通过 ip:port的形式访问rabbitmq的管理界面了. 解决方法很简单: 设置防火墙规则,使外部主机能够访问虚拟机的15672端口. 启动i ...

    8. css 移动端1px更细

      1.最近写项目经常遇到4个入口菜单放在一行,然后加border:1px 在移动端显示却很粗,如下图: <div class="header"> <div clas ...

    9. Ubuntu18.04.3主力开发机使用记录(一)

      现在是2019年12月02日,在公司使用Ubuntu作为开发机器已经有一段时间了 查看主分区创建时间 安装时间8月26 当时周一,一个新的迭代刚刚开始,早上来到公司发现开不了机:Windows报错蓝屏 ...

    10. vultr 更换服务器

      今天打算去p站看看电影 结果发现自己的vps被封了......记录一下换服务器的过程 首先去 https://www.17ce.com/ ping一下,发现只有国外的服务器能ping通 果然是被封了. ...