ZooKeeper常用命令行操作
ZooKeeper常用命令行操作
通过./zkCli.sh 打开zk的客户端进入命令行后台
- ls/ls2 列出当前节点下的子节点 ls2还会列出当前节点的状态
[zk: localhost:2181(CONNECTED) 5] ls2 /
[cluster, controller_epoch, brokers, zookeeper, admin, isr_change_notification, consumers, log_dir_event_notification, latest_producer_id_block, config]
cZxid = 0x0
ctime = Thu Jan 01 08:00:00 CST 1970
mZxid = 0x0
mtime = Thu Jan 01 08:00:00 CST 1970
pZxid = 0x4e
cversion = 14
dataVersion = 0
aclVersion = 0
ephemeralOwner = 0x0
dataLength = 0
numChildren = 10- get 与 stat命令
- stat 列出节点状态 ls2相当于 ls + stat
[zk: localhost:2181(CONNECTED) 6] stat /
cZxid = 0x0
ctime = Thu Jan 01 08:00:00 CST 1970
mZxid = 0x0
mtime = Thu Jan 01 08:00:00 CST 1970
pZxid = 0x4e
cversion = 14
dataVersion = 0
aclVersion = 0
ephemeralOwner = 0x0
dataLength = 0
numChildren = 10- get命令 获取节点内容和节点状态
[zk: localhost:2181(CONNECTED) 8] get /zookeeper cZxid = 0x0 #该节点创建(Create)时的id
ctime = Thu Jan 01 08:00:00 CST 1970
mZxid = 0x0 #该节点修改(Modify)后的id
mtime = Thu Jan 01 08:00:00 CST 1970
pZxid = 0x0 #子节点列表最后一次被修改的事务id
cversion = -1 #子节点的版本号
dataVersion = 0 #当前节点数据的版本号 节点数据改变时这个值会变化
aclVersion = 0 # 权限版本, 权限发生变化时版本号回发生变化
ephemeralOwner = 0x0
dataLength = 0 #数据长度
numChildren = 1 #子节点数量
4.2 zk特性 session的基本原理与create命令使用
客户端与服务端之间的链接存在Session(会话)
每个会话可以设置一个超时时间
心跳机制: 客户端向服务端的ping包请求
心跳结束, session则过期
Session过期, 则临时节点znode会被抛弃
create命令
[zk: localhost:2181(CONNECTED) 10] create /czk czk-data #创建永久节点
Created /czk
[zk: localhost:2181(CONNECTED) 11] get /czk
czk-data
cZxid = 0x50
ctime = Sat Dec 29 17:17:53 CST 2018
mZxid = 0x50
mtime = Sat Dec 29 17:17:53 CST 2018
pZxid = 0x50
cversion = 0
dataVersion = 0
aclVersion = 0
ephemeralOwner = 0x0
dataLength = 12
numChildren = 0
- 创建临时节点 &session过期临时节点删除
[zk: localhost:2181(CONNECTED) 12] create -e /czk/tmp czk-data
Created /itheima/tmp
[zk: localhost:2181(CONNECTED) 13] get /czk
itheima-data
cZxid = 0x50
ctime = Sat Dec 29 17:17:53 CST 2018
mZxid = 0x50
mtime = Sat Dec 29 17:17:53 CST 2018
pZxid = 0x51
cversion = 1
dataVersion = 0
aclVersion = 0
ephemeralOwner = 0x0
dataLength = 12
numChildren = 1
- 创建顺序节点
[zk: localhost:2181(CONNECTED) 1] ls /czk
[]
[zk: localhost:2181(CONNECTED) 2] create -s /czk/sec seq
Created /itheima/sec0000000001
[zk: localhost:2181(CONNECTED) 3] create -s /czk/sec seq
Created /itheima/sec0000000002
[zk: localhost:2181(CONNECTED) 4] ls /czk
[sec0000000001, sec0000000002]
4.3 set/delete 命令
set命令:
set path data [version] # set 路径 数据 [版本号] []内为可选参数
- 不传入版本号
[zk: localhost:2181(CONNECTED) 17] get /czk
czk-data1
cZxid = 0x5b
ctime = Sat Dec 29 17:45:26 CST 2018
mZxid = 0x66
mtime = Sat Dec 29 18:00:12 CST 2018
pZxid = 0x65
cversion = 5
dataVersion = 1
aclVersion = 0
ephemeralOwner = 0x0
dataLength = 13
numChildren = 3
[zk: localhost:2181(CONNECTED) 18] set /czk czk-data2
cZxid = 0x5b
ctime = Sat Dec 29 17:45:26 CST 2018
mZxid = 0x67
mtime = Sat Dec 29 18:02:15 CST 2018
pZxid = 0x65
cversion = 5
dataVersion = 2
aclVersion = 0
ephemeralOwner = 0x0
dataLength = 13
numChildren = 3
[zk: localhost:2181(CONNECTED) 19] get /czk
czk-data2
cZxid = 0x5b
ctime = Sat Dec 29 17:45:26 CST 2018
mZxid = 0x67
mtime = Sat Dec 29 18:02:15 CST 2018
pZxid = 0x65
cversion = 5
dataVersion = 2
aclVersion = 0
ephemeralOwner = 0x0
dataLength = 13
numChildren = 3
- 不传入版本号可能会有并发修改问题 可以通过指定版本号类似加锁功能
[zk: localhost:2181(CONNECTED) 22] set /czk czk-data3 1
version No is not valid : /czk #版本不匹配 修改失败 当前版本2
[zk: localhost:2181(CONNECTED) 23] set /czk czk-data3 2
cZxid = 0x5b
ctime = Sat Dec 29 17:45:26 CST 2018
mZxid = 0x69
mtime = Sat Dec 29 18:29:21 CST 2018
pZxid = 0x65
cversion = 5
dataVersion = 3
aclVersion = 0
ephemeralOwner = 0x0
dataLength = 13
numChildren = 3
[zk: localhost:2181(CONNECTED) 24] get /czk
itheima-data3
cZxid = 0x5b
ctime = Sat Dec 29 17:45:26 CST 2018
mZxid = 0x69
mtime = Sat Dec 29 18:29:21 CST 2018
pZxid = 0x65
cversion = 5
dataVersion = 3
aclVersion = 0
ephemeralOwner = 0x0
dataLength = 13
numChildren = 3
- delete 命令: delete path [version]
[zk: localhost:2181(CONNECTED) 25] ls /czk
[sec0000000003, sec0000000001, sec0000000002]
[zk: localhost:2181(CONNECTED) 27] delete /czk/sec000000000
sec0000000003 sec0000000001 sec0000000002
[zk: localhost:2181(CONNECTED) 27] delete /czk/sec0000000001
[zk: localhost:2181(CONNECTED) 28] ls /czk
[sec0000000003, sec0000000002]
[zk: localhost:2181(CONNECTED) 29] set /czk/sec000000000
sec0000000003 sec0000000002
[zk: localhost:2181(CONNECTED) 29] set /czk/sec0000000002 test2
cZxid = 0x64
ctime = Sat Dec 29 17:49:38 CST 2018
mZxid = 0x6b
mtime = Sat Dec 29 18:54:33 CST 2018
pZxid = 0x64
cversion = 0
dataVersion = 1
aclVersion = 0
ephemeralOwner = 0x0
dataLength = 5
numChildren = 0
[zk: localhost:2181(CONNECTED) 30] delete /czk/sec000000000
sec0000000003 sec0000000002
[zk: localhost:2181(CONNECTED) 30] delete /czk/sec0000000002 0
version No is not valid : /czk/sec0000000002
总结 使用set / delete命令的时候尽量使用版本号 避免误操作
4.4 watcher机制
针对每个节点的操作, 都会有一个监督者->watcher
当监控的某个对象(znode)发生了变化, 则触发watcher事件
zk中的watcher是一次性的, 触发后立即销毁
父节点, 子节点增删改都能触发其watcher
针对不同类型的操作, 触发的watcher事件也不同:
- (子)节点创建事件
- (子)节点删除事件
- (子)节点数据变化事件
watcher命令行
- 通过get path [watch]设置watcher
- 父节点 增 删 改操作触发 watcher
- 子节点 增 删 改操作触发 watcher
创建父节点触发: NodeCreated
- stat path [watch]
[zk: localhost:2181(CONNECTED) 33] stat /czk watch
Node does not exist: /itcast
[zk: localhost:2181(CONNECTED) 35] create /czk 123 WATCHER::Created /czk WatchedEvent state:SyncConnected type:NodeCreated path:/czk- get path [watch]
[zk: localhost:2181(CONNECTED) 36] get /czk watch
123
cZxid = 0x6d
ctime = Sat Dec 29 19:43:13 CST 2018
mZxid = 0x6d
mtime = Sat Dec 29 19:43:13 CST 2018
pZxid = 0x6d
cversion = 0
dataVersion = 0
aclVersion = 0
ephemeralOwner = 0x0
dataLength = 3
numChildren = 0
[zk: localhost:2181(CONNECTED) 37] set /itcast 789 WATCHER:: WatchedEvent state:SyncConnected type:NodeDataChanged path:/czk
cZxid = 0x6d
ctime = Sat Dec 29 19:43:13 CST 2018
mZxid = 0x6e
mtime = Sat Dec 29 19:47:24 CST 2018
pZxid = 0x6d
cversion = 0
dataVersion = 1
aclVersion = 0
ephemeralOwner = 0x0
dataLength = 3
numChildren = 0
- ls/ls2 path [watch]
[zk: localhost:2181(CONNECTED) 38] ls /czk watch
[]
[zk: localhost:2181(CONNECTED) 39] delete /czk WATCHER:: WatchedEvent state:SyncConnected type:NodeDeleted path:/czk
ls为父节点设置watcher, 创建子节点触发:NodeChildrenChanged
ls为父节点设置watcher, 删除子节点触发:NodeChildrenChanged
ls为父节点设置watcher, 修改子节点不触发事件
[zk: localhost:2181(CONNECTED) 49] ls /czk watch
[sec0000000003, dir1, sec0000000002]
[zk: localhost:2181(CONNECTED) 51] create /czk/dir2 123 WATCHER::Created /czk/dir2 WatchedEvent state:SyncConnected type:NodeChildrenChanged path:/czk
[zk: localhost:2181(CONNECTED) 52] ls /czk watch
[sec0000000003, dir2, dir1, sec0000000002]
[zk: localhost:2181(CONNECTED) 53] delete /czk/dir2 WATCHER:: WatchedEvent state:SyncConnected type:NodeChildrenChanged path:/czk
[zk: localhost:2181(CONNECTED) 54]
ZooKeeper常用命令行操作的更多相关文章
- 第4章 ZK基本特性与基于Linux的ZK客户端命令行学习 4-1 zookeeper常用命令行操作
ls path [watch] watch是一个监督者.quota是zookeeper的子目录.目录就是节点的意思,对于zookeeper来说它是以一个节点来说的,所以说/就是根节点,zookeepe ...
- Zookeeper常用命令行及API
一.Zookeeper常用命令行 1.启动zookeeper客户端(在启动zookeeper集群后启动进行调试) zkCli.sh 2.查看帮助.操作历史 help.history 3.查看当前Zno ...
- Zookeeper的命令行操作(三)
Zookeeper的命令行操作 1. ZooKeeper服务命令 在准备好相应的配置之后,可以直接通过zkServer.sh 这个脚本进行服务的相关操作 1. 启动ZK服务: sh bin/zkSer ...
- git 常用命令行操作
git常用命令行操作: 点击 git bash 进入到命令行: git clone https://github.com/wlz1244/qingoo.git //下载一个master分支代码 g ...
- HDFS分布式文件系统的常用命令行操作
一.HDFS的客户端种类 1.网页形式 =>用于测试 网址为你的namenode节点的ip+50070的端口号,如: 192.168.50.128:50070 2.命令行形式 =>用于测 ...
- HBase表的基本结构和常用命令行操作
一.HBase表的基本结构 1.概述: 平时常见的MySQL.Oracle数据库都是传统型关系数据库,它们都是按行查询.按行存储:而HBase为非关系型数据库,它是按列存储的的. 在HBase插入数据 ...
- ZooKeeper常用命令行工具及使用(转)
一.服务端 bin目录下常用的脚本解释 zkCleanup:清理Zookeeper历史数据,包括食物日志文件和快照数据文件 zkCli:Zookeeper的一个简易客户端 zkEnv:设置Zookee ...
- zookeeper客户端命令行操作
一.命令行 (1)使用zookeeper安装bin目录下的./zkCli.sh连接到zookeeper服务器上,基本语法如下: ./zkCli.sh -timeout 0 -r -server ip: ...
- mysql常用命令行操作
1.linux下彻底卸载mysql sudo rm /var/lib/mysql/ -Rsudo rm /etc/mysql/ -R sudo apt-get autoremove mysql* -- ...
随机推荐
- Android源码开发利器——Java源码调试(基于4.1.2)
原文地址:http://blog.csdn.net/jinzhuojun/article/details/8868038 调试Android Java源码 草帽的后花园——Neo 写在之前的 ...
- Linux安装—IP设置
IP设置 务必不要把Linux的IP设置为和我们的真实机位于同一网段(这可能会跟其他机器造成冲突) 具体操作是:在安装虚拟机时Network Type设置选择:Use Host-Only networ ...
- hdu 5532 Almost Sorted Array nlogn 的最长非严格单调子序列
Almost Sorted Array Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 262144/262144 K (Java/Ot ...
- CCPC-Wannafly & Comet OJ 夏季欢乐赛(2019)D
题面 一开始想到一个 O(N^2) 做法,先把x排序,然后顺次枚举x最大的点,看向前最多可以保留多少点 (也就是先不管正方形的上下长度限制,先考虑左右的限制).然后再对这些点做一遍类似的..(等等这么 ...
- Mysql主从同步 异常Slave_SQL_Running: No
在刚搭建好的mysql主从节点上对从节点进行操作,导致同步异常:报错如下: 从节点执行: mysql> show slave status\G;************************* ...
- hadoop-httpfs
Hadoop-httpfs: client向httpfs提交文件操作,由httpfs和集群交互: 优势:client不必访问集群 WebHDFS API: https://archive.cloude ...
- 微信小程序获得unionid
一.微信小程序中app.js中: wx.login({ success: res => { if(res.code){ var code = res.code; wx.getSetting({ ...
- flask-数据库 进阶
1. 级联操作 Cascade意为“级联操作”,就是在操作一个对象的同时,对相关的对象也执行某些操作.我们通过一个Post模型和Comment模型来演示级联操作,分别表示文章(帖子)和评论,两者为一对 ...
- badboy——jmeter录制工具
web网站录制工具 输入网址:红点点被选中代表在录制,然后点点点: 然后导出: 在从JMETER打开:(注意,一定要填cookie)
- C++入门经典-例7.8-const对象,标准尺寸
1:当建立一个对象之后,如果不希望它的任何数据发生改变,可以将其直接声明为const对象,例如: const 类名 对象名 const对象必须初始化.我们可以调用它的数据和函数,但是不可以对他们进行修 ...