zookeeper 学习

2018年6月5日22:40:04 这周内在进行整理

初识 zookeeper

  • 什么是 zookeeper
    zookeeper 是一个开源的分布式协调服务,也是一个提供了分布式数据一致性解决方案的软件。
  • zookeeper 有哪些应用
    数据的发布/订阅(配置中心:disconf、apollo)、负载均衡、集群的 master 选举、分布式队列、分布式锁。
  • zookeeper 的特性
  1. 顺序一致性
    从客户端发送的请求,会严格按照顺序被应用到服务器端。
  2. 原子性
    事务在整个集群中所有机器的应用情况是一致的,要么所有机器都应用,要么所有机器都不应用。
  3. 可靠性
    一旦服务器对某个事务进行了处理,并做出了返回,那么将会在整个集群中进行同步。
  4. 实时性
    一旦事务在服务器端被应用,客户端能立刻从服务端读到数据的变更。(近实时性)

zookeeper 安装

​ 前面说 zookeeper 是开源的软件,安装起来也非常简单,即开即用,解压后可以立即使用。

安装步骤

  1. 下载 zookeeper

  2. 上传后进行解压,因为 zookeeper 是 java 编写的,所以我们需要优先安装 java 环境。

  3. 复制一份 zoo_sample.cfg 文件到 zoo.cfg

  4. 启动 zookeeper 服务端,并尝试通过自带的客户端访问服务端

    zkServer.sh {start|start-foreground|stop|restart|status|upgrade|print-cmd}

zookeeper 集群

​ zookeeper 集群中有三种成员 leader/flower/(observer),一般系统较大的话,会配置 observer 服务器,observer 不参与集群中的投票及选举。

搭建步骤

  1. 配置 myid
  2. 每台机器的 zoo.cfg 配置文件中加入 server.id=host:port1:port2 配置
  3. 重启服务

zookeeper 数据模型

​ zookeeper 有两类节点,一类就存储时间而言,一类就存储规律而言。所以一共有四种节点,分别为下面的 4 种:

  1. 临时节点

    生命周期与客户端的会话保持一致,会话失效,节点自动清理

  2. 临时有序节点

    临时节点加上顺序的特性

  3. 持久化节点

    创建后一直存在于服务器上,直到主动清理

  4. 持久化有序节点

    持久化节点加上了有序的特性

zookeeper Watcher 机制

​ zookeeper 允许客户端向服务器端注册一个 watcher 监听,当服务器端触发了指定事件后会触发 watcher,watcher 通知是一次性的,当服务器端对客户端通知后,watcher 就会失效。使用 watcher 机制可以做我们的配置中心,配置存放在 zookeeper 上,客户端向配置节点注册监听,当节点内容发生变化后,服务器端会对通知客户端,与此同时 watcher 也失效了。

zookeeper ACL

​ zookeeper 提供了控制节点访问权限的功能,用于保证 zookeeper 中数据的安全性,避免错误操作带来的严重后果。

​ 权限控制分为三个维度:scheme id permission

  • scheme 授权策略

    1. digest 用户授权
    2. ip ip授权
    3. world 开放式
    4. super 超级用户
  • id 验证模式

  • permission 权限授权

    CREATE (c) / READ (r) / WRITE (w) / DELETE (d) / ADMIN (a)

zookeeper 会话

​ zookeeper 客户端与服务端建立会话一般会有下面几种状态

  • NOT_CONNECTED
  • CONNECTING
  • CONNECTED
  • CLOSE

zookeeper 操作命令

​ 下面有一些常用的命令

  1. create [-s] [-e] path data acl
  2. get path [watch]
  3. set path data [version]
  4. delete path [version]
  5. ls path [watch]
  6. stat path [watch]
  7. setAcl path acl
  8. getAcl path
  9. addauth scheme auth

zookeeper API

  • zookeeper
  • zkClient
  • curator

zookeeper 应用实现

  • 配置中心
  • 分布式队列
  • 分布式锁
  • 负载均衡
  • master 选举

术语

  1. 中性化、去中心化
  2. 冷备、热备
  3. CAP、BASE 理论
  4. ACID

附录

zoo.cfg 配置解析

# 心跳时间
tickTime=2000 
# 数据目录
dataDir=/tmp/zookeeper 
# server 端与 client 端通信的端口号
clientPort=2181 
# log 存放目录
dataLogDir=/tmp/log/zookeeper 

# 集群初始化连接时,follow 与 leader 之间的最长心跳时间
initLimit=10 
# leader 与 follower 之间的最长心跳时间
syncLimit=5
# 集群服务器配置
server.id=host:port1:port2
maxClientCnxns=60
autopurge.snapRetainCount=3
autopurge.purgeInterval=1

stat 属性解析

# 节点创建的事务ID
cZxid = 0x30                        
# 节点创建时间
ctime = Fri May 25 19:03:21 CST 2018
# 节点最后一次被更新的事务ID
mZxid = 0x30                        
# 节点最后一次的更新时间
mtime = Fri May 25 19:03:21 CST 2018
# 当前节点下的子节点最后一次被修改的事务ID
pZxid = 0x30                        
# 子节点的版本号
cversion = 0                        
# 当前节点的数据的版本号
dataVersion = 0                     
# acl 权限控制的版本号
aclVersion = 0                      
# 创建临时节点时,用于存放 sessionId
ephemeralOwner = 0x0                
# 数据长度
dataLength = 2                      
# 子节点数
numChildren = 0                 
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,776评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,527评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,361评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,430评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,511评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,544评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,561评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,315评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,763评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,070评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,235评论 1 343
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,911评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,554评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,173评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,424评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,106评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,103评论 2 352

推荐阅读更多精彩内容

  • zookeeper介绍 什么是zookeeper? zookpeeper是一个高可用的分布式管理与协调框架,基于Z...
    程序员小宝阅读 794评论 0 3
  • 基本概念 角色zookeeper 集群中的节点共有三种角色,每个节点同时只能是一种角色。集群中的所有机器通过一个 ...
    预流阅读 2,628评论 3 4
  • 1 Zookeeper概述# ZooKeeper是一个为分布式应用所设计的分布的、开源的协调服务,它主要是用来解决...
    七寸知架构阅读 7,347评论 0 101
  • Zookeeper--Zookeeper是什么博客借鉴http://www.cnblogs.com/yuyijq/...
    Albert陈凯阅读 6,034评论 1 36
  • 周六看了一部动漫《元气仔仔》,很神奇的一部动漫,神奇是因为对于我,它有很强的带入感,让我一个下午都沉浸在开怀大笑中...
    duoduo_four阅读 338评论 0 0