概述

zookeeper是一个高可用的分布式数据管理与协调框架,基于ZAB算法实现,主要解决分布式一致性问题。

https://www.cnblogs.com/felixzh/p/5869212.html

核心概念

节点

zk的命名空间是由一系列数据节点组成的,节点上可以包含数据。

类型

节点类型分为:持久节点、临时节点、顺序节点。

创建过程中通过组合有以下4种:

  • CreateMode.PERSISTENT :永久性节点

  • CreateMode.PERSISTENT_SEQUENTIAL :永久性序列节点

  • CreateMode.EPHEMERAL :临时节点,会话断开或过期时会删除此节点

  • CreateMode.PERSISTENT_SEQUENTIAL :临时序列节点,会话断开或过期时会删除此节点

只有叶子节点可以是临时节点,其他节点必须是永久性节点。

状态信息

Stat类中包含了数据节点的所有状态信息。

版本-保证分布式数据原子性操作

zk中数据节点具有3种类型的版本信息:

  • version : 当前数据节点数据内容的版本号

  • cversion: 当前数据节点子节点的版本号

  • aversion: 当前数据节点ACL变更版本号

Watcher-数据变更的通知

zk内部一个重要的特性就是可以监听节点的变化状态。

ACL--保障数据的安全

zk提供了一套完善的Access Control List权限控制机制来保障数据的安全。

客户端

原生

https://www.cnblogs.com/zpb2016/p/5791641.html

http://blog.csdn.net/jiuqiyuliang/article/details/56012027

zkClient.jar

http://blog.csdn.net/wo541075754/article/details/68929512

Curator

全世界使用最广泛的zk客户端之一。

对事件监听、分布式锁、分布式计数器、master选举、分布式Barrier有很好的支持。

应用场景

分布式锁

锁包括排他锁和共享锁,排他锁又成为写锁、独占锁,加锁期间只允许一个事务对其操作。共享锁又成为读锁,当一个事务对数据对象加上共享锁,事务就只能进行数据读取,其他事务也只能对数据对象加共享锁,直到此对象上所有共享锁被释放。

分布式锁实现流程

1.在/app下创建临时节点lock

2.获取/app下所有子节点

3.判断是否是写请求,如果是写请求获取排他锁,自己的lock节点序号节点最小占有锁,然后执行、释放,否则监听比自己序号小的节点,等待锁;

4.如果是读请求,判断自己的lock节点是否是最小的,或者比自己小的都是读请求,如果是占有锁,否则监听比自己序号小的节点,等待锁。

master选举

利用zk的强一致性,能够保证高并发下节点的创建一定能全局唯一性。

实现流程

N台服务在同一时刻同时对/app节点下创建"master"临时子节点,只有其中一台可以创建成功,此时创建成功的便是master,其他服务队/app节点上注册子节点变更的watcher,如果master挂了,其他服务重新进行选举。

配置中心

配置中心也可以叫做数据发布/订阅系统。zk内部采用的是推拉相结合的方式:客户端向服务端注册需要关注的节点,一旦节点数据发生变更,服务端就会向相应的客户端发送watcher事件通知,客户端接收到消息后,需要主动到服务端获取最新的数据。

命名服务

在zk中,每一个数据节点都能够维护一份子节点的顺序顺列,当客户端对其创建一个顺序子节点的时候zk会自动以后缀的形式在其子节点上添加一个序号,命名服务即使利用zk的这种特性。

动态DNS服务

分布式队列/屏障

zookeeper学习整理的更多相关文章

  1. js数组学习整理

    原文地址:js数组学习整理 常用的js数组操作方法及原理 1.声明数组的方式 var colors = new Array();//空的数组 var colors = new Array(3); // ...

  2. TweenMax学习整理--特有属性

    TweenMax学习整理--特有属性   构造函数:TweenMax(target:Object, duration:Number, vars:Object) target:Object -- 需要缓 ...

  3. HttpClient学习整理

    HttpClient简介HttpClient 功能介绍    1. 读取网页(HTTP/HTTPS)内容    2.使用POST方式提交数据(httpClient3)    3. 处理页面重定向    ...

  4. !!对python列表学习整理列表及数组详细介绍

    1.Python的数组分三种类型:(详细见 http://blog.sina.com.cn/s/blog_6b783cbd0100q2ba.html) (1) list 普通的链表,初始化后可以通过特 ...

  5. Java设计模式(学习整理)---命令模式

    设计模式之Command(学习整理) 1.Command定义 不少Command模式的代码都是针对图形界面的,它实际就是菜单命令,我们在一个下拉菜单选择一个命令时,然后会执行一些动作. 将这些命令封装 ...

  6. Wix学习整理(5)——安装时填写注册表

    原文:Wix学习整理(5)--安装时填写注册表 一 Microsoft操作系统的注册表 什么是注册表? 注册表是Mircrosoft Windows中的一个重要的数据库,用于存储系统和应用程序的设置信 ...

  7. Wix学习整理(6)——安装快捷方式

    原文:Wix学习整理(6)--安装快捷方式 一 为HelloWorld案例添加安装快捷方式 通常我们安装一个应用软件的时候,都喜欢在桌面或开始菜单中添加快捷方式以便我们快速访问.现在我们就在上篇添加注 ...

  8. Wix学习整理(7)——在开始菜单中为HelloWorld添加卸载快捷方式

    原文:Wix学习整理(7)--在开始菜单中为HelloWorld添加卸载快捷方式 通过前面的几篇随笔,我们已经给我们的HelloWorld提供了填写注册表信息,以及开始菜单快捷方式和桌面快捷方式.这些 ...

  9. Wix学习整理(4)——关于WiX文件格式和案例HelloWorld的分析

    原文:Wix学习整理(4)--关于WiX文件格式和案例HelloWorld的分析 关于WiX文件格式 .wxs是WiX的源文件扩展名..wxs文件以类XML文件的格式来指定了要构造Windows In ...

随机推荐

  1. 最小圆覆盖(洛谷 P1742 增量法)

    题意:给定N个点,求最小圆覆盖的圆心喝半径.保留10位小数点. N<1e5: 思路:因为精度要求较高,而且N比较大,所以三分套三分的复杂度耶比较高,而且容易出错. 然是写下增量法吧. 伪代码加深 ...

  2. es6 添加事件监听

    //定义被侦听的目标对象 }; //定义处理程序 var interceptor = { set: function (receiver, property, value) { console.log ...

  3. Vue --- 基础指令

    目录 表单指令 条件指令 循环指令 分隔符(了解) 过滤器 计算属性 监听属性 冒泡排序 表单指令 使用方法: v-model 数据双向绑定 v-model绑定的变量可以影响表单标签的值,反过来表单标 ...

  4. 用junit Test Suite来组合测试

    在测试过程中,有时可能想一次性运行所有的测试类,或是选择性的运行某些测试类.这样的话我们就可以用TestSuite来统一管理我们的测试类. 比如说我现在有三个测试类:junitTest4,TestCa ...

  5. MQTT 遗嘱使用

    大部分人应该有这个需求: 我想让我的APP或者上位机或者网页一登录的时候获取设备的状态   在线还是离线 设备端只需要这样设置 注意:MQTT本身有遗嘱设置 所以大家可以设置遗嘱 ,注意哈,发布的主题 ...

  6. Cogs 1632. 搬运工(二分图最小点覆盖)

    搬运工 ★ 输入文件:worker.in 输出文件:worker.out 简单对比 时间限制:1 s 内存限制:256 MB [题目描述] 小涵向小宇推荐了一款小游戏. 游戏是这样的,在一个n*n的地 ...

  7. 干货 | 10分钟带你掌握branch and price(分支定价)算法超详细原理解析

    00 前言 相信大家对branch and price的神秘之处也非常好奇了.今天我们一起来揭秘该算法原理过程.不过,在此之前,请大家确保自己的branch and bound和column gene ...

  8. (11)Go方法/接收者

    方法和接收者 Go语言中的方法(Method)是一种作用于特定类型变量的函数.这种特定类型变量叫做接收者(Receiver).接收者的概念就类似于其他语言中的this或者 self. 方法的定义格式如 ...

  9. OpenFOAM——圆腔顶盖旋转驱流

    本算例来自<ANSYS Fluid Dynamics Verification Manual>中的VMFL008: Flow Inside a Rotating Cavity 腔体顶盖以1 ...

  10. spring 整合 servlet

    目的:记录spring整合 servlet过程demo.(企业实际开发中可能很少用到),融会贯通. 前言:在学习spring 过程(核心 ioc,aop,插一句 学了spring 才对这个有深刻概念, ...