1.ZooKeeper是什么 

  ZooKeeper为分布式应用提供了高效且可靠的分布式协调服务,提供了统一命名服务、 配置管理和分布式锁等分布式的基础服务。在解决分布式数据一致性方面, ZooKeeper采用的是 ZAB (ZooKeeperAtomic Broadcast)的一致性协议。

  ZooKeeper是一个典型的分布式数据一致性的解决方案, 分布式应用程序可以基于它实现现诸如数据发布/订阅、负载均衡、命名服务、分布式协调/通知、集群管理、 Maste选举、 分布式锁和分布式队列等功能。

  ZooKeeper可以保证如下分布式一致性特性:

  1.顺序一致性:从同一个客户端发起的事务请求, 最终将会严格地按照其发起顺序被应用到Zookeeper中去。

   2.原子性:所有事务请求的处理结果在整个集群中所有机器上的应用情况是一致的。

  3.单一视图( Sing1eSvsfem/mage):无论客户端连接的是哪个 ZooKeeper服务器,其看到的服务端数据模型都是一致的 。

  4.实时性:ZooKeeper仅仅保证在一定的时间段内, 客户端最终一定能够从服务端上读取到最新的数据状态。

2.ZooKeeper的设计目标

  目标一 : 简单的数据模型

    Zookeeper使得分布式程序能够通过一个共享的、树形结构的名字空间来进行相互协调。由一系列的被称为ZNODE的数据节点构成。类似于文件系统,但是Zookeeper将全部数据都存放在内存中,以提高服务器吞吐,减少延迟。

  

  目标二:构建集群

    组成 ZooKeeper集群的每台机器都会在内存中维护当前的服务器状态, 并且每台机器之间都互相保持着通信。只要集群中存在超过一半的机器能够正常工作,那么整个集群就能够正常对外服务。ZooKeeper的客户端程序会选择和集群中任意一台机器共同来创建一个 TcP连接,当客户端和某台 ZooKeeper服务器之间的连接断开后, 客户端会自动连接到集群中的其他机器。

  目标三:顺序访问

  对于来自客户端的每个更新请求,zookeeper会分配一个全局唯一的递增编号,这个编号反应了所有事务的操作先后顺序。

  目标四:高性能

  ZooKeeper将全量数据存储在内存中,并直接服务于客户端的所有非事务请求,适用于以读操作为主的应用场景。

3.ZooKeeper的基本概念

  集群

  在分布式系统中, 典型的集群模式是 Master/Slave模式(主备模式)。能够处理所有写操作的机器称为 Master机器, 把所有通过异步复制方式获取最新数据, 并提供读服务的机器称为Slave机器。

  Zookeeper没有沿用Master/Slave概念,引入了Leader、 Follower和 Observer三种角色。ZooKeeper集群中的所有机器通过fastLeader选举算法选定一台Leader,Leader服务器为客户端提供读和写服务。除 Leader外,其他机器包括 Follower和 〇bserver。 Follower和 Observer都能够提供读服务,唯一的区别在于, Observer机器不参与 Leader选举过程,也不参与写操作的“过半写成功”策略,因此 Observer可以在不影响写性能的情况下提升集群的读性能。

  会话(Session)

  zooKeeper中, 一个客户端连接是指客户端和服务器之间的一个 TCP长连接。 ZooKeeper对外的服务端口默认是2181 ,客户端启动的时候,首先会与服务器建立一个 TCP连接, 通过这个连接, 客户端能够通过心跳检测与服务器保持有效的会话, 也能够向 ZooKeeper服务器发送请求,接受响应,同时还能够通过该连接接收来自服务器的 Watch事件通知。Session的 sessionTimeout值用来设置一个客户端会话的超时时间。 当由于服务器压力太大、 网络故障或是客户端主动断开连接等各种原因导致客户端连接断开时, 只要在 sessionTimeout规定的时间内能够重新连接上集群中任意一台服务器,那么之前创建的会话仍然有效。

  数据节点(Znode)

  ZooKeeper中,节点分为两类,第一类为机器节点,指构成集群的机器;第二类为数据节点ZNode。ZNode可以分为持久节点和临时节点两类。

  持久节点是指除非主动进行 ZNode的移除操作, 否则这个 ZNode将一直保存在ZooKeeper上。

  临时节点的生命周期和客户端会话绑定, 一旦客户端会话失效, 这个客户端创建的所有临时节点都会被移除。

  

  版本

  对应于每个 ZNode,ZooKeeper都会为其维护一个叫作 Stat的数据结构, Stat中记录了这个 ZNode的三个数据版本,分别是 version(当前 ZNode的版本)、 cversion(当前ZNode子节点的版本)和 aversion(当前 ZNode的 ACL版本)。

  Watcher

  用户可以在指定节点上注册一些 watcher,井且在一些特定事件触发的时候, ZooKeePer服务端会将事件通知到感兴趣的客户端上去。

  ACL

  ZooKeeper定义了如下5种权限:

    CREATE:创建子节点的权限。

    READ: 获取节点数据和子节点列表的权限。

    WRITE:更新节点数据的权限。

    DELETE:删除子节点的权限。

    ADMIN:设置节点 ACL的权限。

  此处注意,CREATE和 DELETE这两种权限都是针对子节点的权限控制。对一个会话赋予/a节点的delete权限时,此会话拥有删除/a的子节点的权限,而不是删除/a节点的权限。

  

第一章 zookeeper基础概念的更多相关文章

  1. Vue.js-01:第一章 - 一些基础概念

    一.前言 Vue.React.Angular,当今前端界的三驾马车,作为传统的后端程序员,前端再也不是我们想的那种切切图就可以了,第一次接触的话,先了解了解一些基础的概念. 学习系列目录地址:http ...

  2. 第一章 –– Java基础语法

    第一章 –– Java基础语法 span::selection, .CodeMirror-line > span > span::selection { background: #d7d4 ...

  3. 《零成本实现Web自动化测试--基于Selenium》第一章 自动化测试基础

    第一篇 Selenium 和WebDriver工具篇 第一章 自动化测试基础 1.1    初识自动化测试 自动化测试有两种常见方式 1.1.1 代码驱动测试,又叫测试驱动开发(TDD) 1.1.2 ...

  4. [Python笔记][第一章Python基础]

    2016/1/27学习内容 第一章 Python基础 Python内置函数 见Python内置函数.md del命令 显式删除操作,列表中也可以使用. 基本输入输出 input() 读入进来永远是字符 ...

  5. 第一章 jQuery基础

    第一章jQuery基础 一.jQuert简介 1.什么是jQuery jQuery是javaScript的程序库之一,它是javaScript对象和实用函数的封装. jQuery是继Prototype ...

  6. web前端学习python之第一章_基础语法(二)

    web前端学习python之第一章_基础语法(二) 前言:最近新做了一个管理系统,前端已经基本完成, 但是后端人手不足没人给我写接口,自力更生丰衣足食, 所以决定自学python自己给自己写接口哈哈哈 ...

  7. web前端学习python之第一章_基础语法(一)

    web前端学习python之第一章_基础语法(一) 前言:最近新做了一个管理系统,前端已经基本完成, 但是后端人手不足没人给我写接口,自力更生丰衣足食, 所以决定自学python自己给自己写接口哈哈哈 ...

  8. UNIX环境高级编程--第一章 UNIX基础知识

    第一章 UNIX基础知识 1.2 UNIX体系结构   从严格意义上说,可将操作系统定义为一种软件,它控制计算机硬件资源,提供程序运行环境.我们将这种软件称为内核(kernel),因为 它相对较小,且 ...

  9. python第一章计算机基础

    第一章 计算机基础 1.1 硬件 计算机基本的硬件由:CPU / 内存 / 主板 / 硬盘 / 网卡 / 显卡 / 显示器 等组成,只有硬件但硬件之间无法进行交流和通信. 1.2 操作系统 操作系统用 ...

随机推荐

  1. 也谈Oracle异常: ORA-06502: PL/SQL: 数字或值错误 : 字符串缓冲区太小

    场景: .Net程序调用Oracle方法 command.ExecuteNonQuery()执行存储过程;弹出如标题异常信息. 存储过程有4个输入参数,一个输出参数.一旦执行到给输出参数赋值的时候就报 ...

  2. OAF_JDBC系列1 - 数据库交互取值方式(案例)

    2014-06-15 Created By BaoXinjian

  3. No.5__C#

    One month 今天是个有纪念意义的日子,2015-4-23.今天是实习的第一个月,算是成就达成吧.虽然,除去了周末六日和清明什么的,只剩下20多天了,但是,还是好开心 啊,毕竟是第一次参加工作, ...

  4. Blackfin DSP(七):用SPORT口模拟SPI

    1.问题的提出 当系统从SPI device启动时,若SCLK = 133M,则SPI的最大速度为33M.然而,有一些串行的flash设备能更快的运行,因此,如果我们使用SPORT口,它的最大速度为S ...

  5. 用 Navicat 写mysql的游标

    千言万语也比不上一个简单直接明了的小例子: CREATE PROCEDURE pro_users() begin DECLARE myid int; DECLARE no int; ); ); ); ...

  6. scrollWidth的巧妙运用

    再了无生趣的工作也是能够帮助我们提高的~ 最近工作比较无聊,于是就想到了写一个滚动条插件,在借鉴了mCustomerScrollbar这个组件之后我简单的写了一个类似的,当然,相比于它的2000多行代 ...

  7. xml 中转意字符&\/使用方法

    所有 XML 元素都须有关闭标签 在 HTML,经常会看到没有关闭标签的元素: <p>This is a paragraph <p>This is another paragr ...

  8. Inside The C++ Object Model - 03

    object Lessons 1.C++中布局以及存取时间上的的额外负担是由virtual引起的:virtual function.virtual base class.或是由于多继承引起的. 2.C ...

  9. Python Django之路由系统

    1.初识路由系统 路由系统是用户发请求到URL,然后URL根据路由系统重新指向到函数名的一个对应关系 2.创建project和app django-admin startproject mysite ...

  10. 错误:Unsupported major.minor version 51.0(jdk版本错误)的解决方法

    错误:Unsupported major.minor version 51.0(jdk版本错误)的解决方法 java.lang.UnsupportedClassVersionError: org/ap ...