连接zk
1
2
cd bin
zkCli.sh -timeout 5000 -server 27.154.242.214:5091

输入h,回车查看帮助
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
[zk: 27.154.242.214:5091(CONNECTED) 2] h
ZooKeeper -server host:port cmd args
    stat path [watch]
    set path data [version]
    ls path [watch]
    delquota [-n|-b] path
    ls2 path [watch]
    setAcl path acl
    setquota -n|-b val path
    history 
    redo cmdno
    printwatches on|off
    delete path [version]
    sync path
    listquota path
    rmr path
    get path [watch]
    create [-s] [-e] path data acl
    addauth scheme auth
    quit 
    getAcl path
    close 
    connect host:port

创建节点
1
2
[zk: 27.154.242.214:5091(CONNECTED) 11] create /note1 123
Created /note1

-s 表示是顺序节点 -e表示为临时节点

创建临时节点
(会话结束节点就被删除,qiut(退出) 然后在登陆 )
1
2
[zk: 27.154.242.214:5091(CONNECTED) 11] create
-e 
/note2 123
Created /note2

顺序节点

(应用场景:分布式的主键生成器)

1
2
3
4
[zk: 27.154.242.214:5091(CONNECTED) 1] create -s /note1/note13 1333
Created /note1/note130000000002
[zk: 27.154.242.214:5091(CONNECTED) 2] create -s /note1/note13 1333
Created /note1/note130000000003


查看节点状态

1
2
3
4
5
6
7
8
9
10
11
12
[zk: 27.154.242.214:5091(CONNECTED) 12] stat /note1
cZxid = 0xc0b
ctime = Sun Aug 21 07:42:06 CST 2016
mZxid = 0xc0b
mtime = Sun Aug 21 07:42:06 CST 2016
pZxid = 0xc0b
cversion = 0
dataVersion = 0
aclVersion = 0
ephemeralOwner = 0x0
dataLength = 3
numChildren = 0
说明:每一次操作都是一个事务,每一个事务都有一个事务id
2. cZxid 该节点被创建的时候的事务id
3. ctime 节点被创建的时间
4. mZxid 最后一次更新的事务id
5. mtime 最后一次更新的时间
6. pZxid 该节点的子节点最后一次修改的事务id(修改子节点的内容不算)
7. cversion 子节点的版本号
8. dataVersion 数据版本号
9. aclVersion acl权限版本号
10. ephemeralOwner 创建临时节点的事务id(永久节点的话 这个值固定为0)
11. dataLength 当前节点存放数据长度
12. numChinldren 当前节点拥有子节点的个数

获取当前节点存储的数据的内容
1
2
3
4
5
6
7
8
9
10
11
12
13
[zk: 27.154.242.214:5091(CONNECTED) 13] get /note1
123
cZxid = 0xc0b
ctime = Sun Aug 21 07:42:06 CST 2016
mZxid = 0xc0b
mtime = Sun Aug 21 07:42:06 CST 2016
pZxid = 0xc0b
cversion = 0
dataVersion = 0
aclVersion = 0
ephemeralOwner = 0x0
dataLength = 3
numChildren = 0

ls2列出当前节点的子节点同时输出stat信息

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
[zk: 27.154.242.214:5091(CONNECTED) 16] create /note1/note11 456
[zk: 27.154.242.214:5091(CONNECTED) 18] create /note1/note12 789
[zk: 27.154.242.214:5091(CONNECTED) 19] ls2 /note1              
[note12, note11]
cZxid = 0xc0b
ctime = Sun Aug 21 07:42:06 CST 2016
mZxid = 0xc0b
mtime = Sun Aug 21 07:42:06 CST 2016
pZxid = 0xc0d
cversion = 2
dataVersion = 0
aclVersion = 0
ephemeralOwner = 0x0
dataLength = 3
numChildren = 2

修改
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
[zk: 27.154.242.214:5091(CONNECTED) 8] set /note1/note11 111
cZxid = 0xc0c
ctime = Sun Aug 21 07:47:28 CST 2016
mZxid = 0xc15
mtime = Sun Aug 21 09:12:07 CST 2016
pZxid = 0xc0c
cversion = 0
dataVersion = 1
aclVersion = 0
ephemeralOwner = 0x0
dataLength = 3
numChildren = 0
[zk: 27.154.242.214:5091(CONNECTED) 9] get /note1/note11    
111
cZxid = 0xc0c
ctime = Sun Aug 21 07:47:28 CST 2016
mZxid = 0xc15
mtime = Sun Aug 21 09:12:07 CST 2016
pZxid = 0xc0c
cversion = 0
dataVersion = 1
aclVersion = 0
ephemeralOwner = 0x0
dataLength = 3
numChildren = 0
再进行修改,dataversion会一直增加上去

删除节点

(rmr 循环删除节点及其子节点)

1
2
3
4
5
6
7
8
[zk: 27.154.242.214:5091(CONNECTED) 10] delete /note1/note11
[zk: 27.154.242.214:5091(CONNECTED) 11] ls /note1           
[note12, note130000000002, note130000000003]
[zk: 27.154.242.214:5091(CONNECTED) 12] delete /note1
Node not empty: /note1
[zk: 27.154.242.214:5091(CONNECTED) 13] rmr /note1
[zk: 27.154.242.214:5091(CONNECTED) 14] ls /  
[server, zookeeper, config]

配额相关的指令

设置配额

[setquota -n|-b val path]

-n限制子节点的个数 –b限制数据的长度

1
2
3
4
5
6
7
8
9
10
[zk: 27.154.242.214:5091(CONNECTED) 18] create /note1 123    
Created /note1
[zk: 27.154.242.214:5091(CONNECTED) 19] setquota -n 2 /note1 
Comment: the parts are option -n val 2 path /note1
[zk: 27.154.242.214:5091(CONNECTED) 20] create /note1/note11 11 
Created /note1/note11
[zk: 27.154.242.214:5091(CONNECTED) 21] create /note1/note12 12
Created /note1/note12
[zk: 27.154.242.214:5091(CONNECTED) 22] create /note1/note13 13  
Created /note1/note13

发现超限了仅仅在日志记录超限信息的警告不会有异常如下:

1
2
3
4
5
6
7
8
9
10
11
12
13
[lzmhdev@lzmh01 zookeeper-3.4.8]$ cd bin 
[lzmhdev@lzmh01 bin]$ ls
README.txt  zkCleanup.sh  zkCli.cmd  zkCli.sh  zkEnv.cmd  zkEnv.sh  zkServer.cmd  zkServer.sh  zookeeper.out
[lzmhdev@lzmh01 bin]$ tail -f zookeeper.out 
    at java.lang.Thread.run(Thread.java:745)
2016-08-21 08:54:07,402 [myid:] - INFO  [NIOServerCxn.Factory:0.0.0.0/0.0.0.0:5091:NIOServerCnxn@1008] - Closed socket connection for client /123.59.54.18:34285 which had sessionid 0x156aa06f8d60001
2016-08-21 08:54:12,000 [myid:] - INFO  [SessionTracker:ZooKeeperServer@355] - Expiring session 0x156aa06f8d60001, timeout of 5000ms exceeded
2016-08-21 08:54:12,001 [myid:] - INFO  [ProcessThread(sid:0 cport:5091)::PrepRequestProcessor@489] - Processed session termination for sessionid: 0x156aa06f8d60001
2016-08-21 08:54:21,201 [myid:] - INFO  [NIOServerCxn.Factory:0.0.0.0/0.0.0.0:5091:NIOServerCnxnFactory@192] - Accepted socket connection from /123.59.54.18:34338
2016-08-21 08:54:21,205 [myid:] - INFO  [NIOServerCxn.Factory:0.0.0.0/0.0.0.0:5091:ZooKeeperServer@900] - Client attempting to establish new session at /123.59.54.18:34338
2016-08-21 08:54:21,223 [myid:] - INFO  [SyncThread:0:ZooKeeperServer@645] - Established session 0x156aa06f8d60002 with negotiated timeout 5000 for client /123.59.54.18:34338
2016-08-21 09:14:54,075 [myid:] - INFO  [ProcessThread(sid:0 cport:5091)::PrepRequestProcessor@651] - Got user-level KeeperException when processing sessionid:0x156aa06f8d60002 type:delete cxid:0x15 zxid:0xc17 txntype:-1 reqpath:n/a Error Path:/note1 Error:KeeperErrorCode = Directory not empty for /note1
2016-08-21 10:10:41,080 [myid:] - WARN  [SyncThread:0:DataTree@389] - Quota exceeded: /note1 count=3 limit=2

查看指定数据节点的配额情况

1
2
3
4
[zk: 27.154.242.214:5091(CONNECTED) 23] listquota /note1
absolute path is /zookeeper/quota/note1/zookeeper_limits
Output quota for /note1 count=2,bytes=-1
Output stat for /note1 count=4,bytes=9

-1 长度没有限制

删除配额

1
2
3
4
5
[zk: 27.154.242.214:5091(CONNECTED) 24] delquota -n /note1
[zk: 27.154.242.214:5091(CONNECTED) 25] listquota /note1  
absolute path is /zookeeper/quota/note1/zookeeper_limits
Output quota for /note1 count=-1,bytes=-1
Output stat for /note1 count=4,bytes=9

查看历史

并重复执行

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
[zk: 27.154.242.214:5091(CONNECTED) 26] history
16 - create /note1
17 - setquota -n 2 /note1 
18 - create /note1 123
19 - setquota -n 2 /note1 
20 - create /note1/note11 11
21 - create /note1/note12 12
22 - create /note1/note13 13
23 - listquota /note1
24 - delquota -n /note1
25 - listquota /note1
26 - history
[zk: 27.154.242.214:5091(CONNECTED) 27] redo 25
absolute path is /zookeeper/quota/note1/zookeeper_limits
Output quota for /note1 count=-1,bytes=-1
Output stat for /note1 count=4,bytes=9
参考
        极客学院视频【链接:http://pan.baidu.com/s/1qYKPNyO 密码:nlz3】




ZooKeeper 客户端的使用的更多相关文章

  1. 【分布式】Zookeeper客户端

    一.前言 前篇博客分析了Zookeeper的序列化和通信协议,接着继续学习客户端,客户端是开发人员使用Zookeeper最主要的途径,很有必要弄懂客户端是如何与服务端通信的. 二.客户端 2.1 客户 ...

  2. zookeeper 客户端编程

    zookeeper是一个分布式的开源的分布式协调服务,用它可以来现同步服务,配置维护.zookeeper的稳定性也是可以保证的,笔者曾参与过的使用zookeeper的两个应用,一个是用zookeepe ...

  3. ZooKeeper客户端事件串行化处理

    为了提升系统的性能,进一步提高系统的吞吐能力,最近公司很多系统都在进行异步化改造.在异步化改造的过程中,肯定会比以前碰到更多的多线程问题,上周就碰到ZooKeeper客户端异步化过程中的一个死锁问题, ...

  4. zookeeper客户端操作

    ZooKeeper客户端 zkCli.sh 节点的增删改查 在 bin 目录下的  zkCli.sh  就是ZooKeeper客户端 ./zkCli.sh -timeout 5000  -server ...

  5. zookeeper客户端 zkCli使用及常用命令

    上篇(http://www.cnblogs.com/yangzhenlong/p/8270835.html)zk伪集群搭建好后,使用zkCli连接zk服务 切换到zk1/bin 目录,执行zkCli. ...

  6. Zookeeper客户端Curator基本API

    在使用zookeper的时候一般不使用原生的API,Curator,解决了很多Zookeeper客户端非常底层的细节开发工作,包括连接重连.反复注册Watcher和NodeExistsExceptio ...

  7. Zookeeper客户端Curator的使用,简单高效

    Curator是Netflix公司开源的一个Zookeeper客户端,与Zookeeper提供的原生客户端相比,Curator的抽象层次更高,简化了Zookeeper客户端的开发量. 1.引入依赖: ...

  8. Zookeeper客户端介绍

    客户端是开发人员使用Zookeeper的主要的途径,以下内容将对Zookeeper的内部原理进行详细的学习和讲解.ZooKeeper的客户端主要有一下几个核心组件组成: Zookeeper:提供客户端 ...

  9. ZooKeeper客户端 zkCli.sh 节点的增删改查

    zkCli.sh 在 bin 目录下的  zkCli.sh  就是ZooKeeper客户端 ./zkCli.sh -timeout 5000  -server 127.0.0.1:2181  客户端与 ...

  10. Zookeeper客户端Curator使用详解

    Zookeeper客户端Curator使用详解 前提 最近刚好用到了zookeeper,做了一个基于SpringBoot.Curator.Bootstrap写了一个可视化的Web应用: zookeep ...

随机推荐

  1. ACM 人见人爱A^B

    求A^B的最后三位数表示的整数. 说明:A^B的含义是"A的B次方"  Input输入数据包含多个测试实例,每个实例占一行,由两个正整数A和B组成(1<=A,B<=10 ...

  2. Node.js 系统

    稳定性: 4 - API 冻结 提供一些基本的操作系统相关函数. 使用 require('os') 访问这个模块. os.tmpdir() 返回操作系统的默认临时文件夹 os.endianness() ...

  3. JMETER_从入门到放弃系列

    基础篇 Jmeter(一)_环境部署 Jmeter(二)_基础元件 Jmeter(三)_配置元件 Jmeter(四)_16个逻辑控制器 Jmeter(五)_24个函数 Jmeter(六)_前置处理器 ...

  4. Android开发艺术探索第五章——理解RemoteViews

    Android开发艺术探索第五章--理解RemoteViews 这门课的重心在于RemoteViews,RemoteViews可以理解为一种远程的View,其实他和远程的Service是一样的,Rem ...

  5. Swift按照数组元素出现的次数及大小排序

    要求如下: 1.已知一个数组,按照单个元素在数组中出现的次数作为重新排序的依据,个数多的排在前面 2.相同个数时候,元素值大的排前面 例子: [1, 2, 2, 3, 5, 5] 经过计算得到的结果是 ...

  6. 针对于Python的OpenCV环境搭建

    OpenCV 依赖 下载OpenCV 配置 总结 给Python搭建opencv的环境还真是略嫌麻烦,于是做下笔记,以备不时之需. OpenCV 依赖 opencv有些依赖,我们必须安装一下,否则接下 ...

  7. Python 3 智能发音

    真是十分神奇.. import win32com.client import time s = win32com.client.Dispatch("SAPI.SpVoice") s ...

  8. Linux 环境下一些常用命令(四)

    转自 http://www.oschina.net/translate/20-advanced-commands-for-middle-level-linux-users 31. 命令: rm 'rm ...

  9. GDAL 2.0版本RPC校正速度测试

    GDAL2.0版本的更新日志中提到了对RPC校正的优化,今天测试了一下,发现提升的速度还是蛮快的,测试的数据是一个IRS-P5的数据. 单线程测试 首先使用一个线程进行测试,使用下面的批处理进行运行, ...

  10. 皮尔森相似度计算举例(R语言)

    整理了一下最近对协同过滤推荐算法中的皮尔森相似度计算,顺带学习了下R语言的简单使用,也复习了概率统计知识. 一.概率论和统计学概念复习 1)期望值(Expected Value) 因为这里每个数都是等 ...