ZooKeeper学习笔记(四)——shell客户端命令操作
ZooKeeper客户端命令行操作
启动服务端
[simon@hadoop102 zookeeper-3.4.10]$ bin/zkServer.sh start
查看状态信息
Using config: /opt/module/zookeeper-3.4.10/bin/../conf/zoo.cfg
Starting zookeeper ... STARTED
[simon@hadoop102 zookeeper-3.4.10]$ bin/zkServer.sh status
ZooKeeper JMX enabled by default
Using config: /opt/module/zookeeper-3.4.10/bin/../conf/zoo.cfg
Mode: follower
启动客户端
[simon@hadoop102 zookeeper-3.4.10]$ bin/zkCli.sh
查看当前znode中所包含的内容
[zk: localhost:2181(CONNECTED) 1] ls /
[zookeeper]
查看当前节点的详细数据
[zk: localhost:2181(CONNECTED) 2] ls2 /
[zookeeper]
cZxid = 0x0
ctime = Thu Jan 01 08:00:00 CST 1970
mZxid = 0x0
mtime = Thu Jan 01 08:00:00 CST 1970
pZxid = 0x0
cversion = -1
dataVersion = 0
aclVersion = 0
ephemeralOwner = 0x0
dataLength = 0
numChildren = 1
分别创建两个普通节点
[zk: localhost:2181(CONNECTED) 3] create /simon "user"
[zk: localhost:2181(CONNECTED) 0] create /simon/a "a"
Created /simon/a
获得节点的值
[zk: localhost:2181(CONNECTED) 1] get /simon
user
cZxid = 0x100000004
ctime = Thu Oct 24 21:59:31 CST 2019
mZxid = 0x100000004
mtime = Thu Oct 24 21:59:31 CST 2019
pZxid = 0x100000007
cversion = 1
dataVersion = 0
aclVersion = 0
ephemeralOwner = 0x0
dataLength = 4
numChildren = 1 [zk: localhost:2181(CONNECTED) 2] get /simon/a
a
cZxid = 0x100000007
ctime = Thu Oct 24 22:19:10 CST 2019
mZxid = 0x100000007
mtime = Thu Oct 24 22:19:10 CST 2019
pZxid = 0x100000007
cversion = 0
dataVersion = 0
aclVersion = 0
ephemeralOwner = 0x0
dataLength = 1
numChildren = 0
创建临时节点
[zk: localhost:2181(CONNECTED) 3] create -e /simon/temp "temp"
Created /simon/temp
(1)在客户端可以查看到
[zk: localhost:2181(CONNECTED) 5] ls /simon
[a, temp](2)退出当前客户端之后再重启客户端
[zk: localhost:2181(CONNECTED) 6] quit
Quitting...
2019-10-24 22:22:00,789 [myid:] - INFO [main:ZooKeeper@684] - Session: 0x26dfe0bc0f60002 closed
2019-10-24 22:22:00,790 [myid:] - INFO [main-EventThread:ClientCnxn$EventThread@519] - EventThread shut down for session: 0x26dfe0bc0f60002 [simon@hadoop102 zookeeper-3.4.10]$ bin/zkCli.sh(3)再次查看根目录下临时节点已经被删除
[zk: localhost:2181(CONNECTED) 0] ls /simon
[a]创建带序号的节点
(1)先创建一个普通的根节点
/simon/b[zk: localhost:2181(CONNECTED) 1] create /simon/b "b"
Created /simon/b(2)创建一个带序号的节点
[zk: localhost:2181(CONNECTED) 1] create -s /simon/b/ba "ba"
Created /simon/b/ba0000000001
[zk: localhost:2181(CONNECTED) 2] create -s /simon/b/bb "bb"
Created /simon/b/bb0000000002
[zk: localhost:2181(CONNECTED) 3] create -s /simon/b/bc "bc"
Created /simon/b/bc0000000003如果原来没有节点序号,序号从0开始依次递增。如果原节点下已经有2个节点,则再排序时从2开始,以此类推。
修改节点数据的值
[zk: localhost:2181(CONNECTED) 4] set /simon/b "B" [zk: localhost:2181(CONNECTED) 5] get /simon/b
[zk: localhost:2181(CONNECTED) 5] get /simon/b
B
cZxid = 0x10000000b
ctime = Thu Oct 24 22:23:07 CST 2019
mZxid = 0x100000012
mtime = Thu Oct 24 22:26:16 CST 2019
pZxid = 0x100000011
cversion = 4
dataVersion = 1
aclVersion = 0
ephemeralOwner = 0x0
dataLength = 1
numChildren = 4节点值的变化监听
(1)在Hadoop104主机上注册监听
/simon节点数据的变化[zk: localhost:2181(CONNECTED) 0] get /simon watch #监听根节点用:get 子节点:ls
user
cZxid = 0x100000004
ctime = Thu Oct 24 21:59:31 CST 2019
mZxid = 0x100000004
mtime = Thu Oct 24 21:59:31 CST 2019
pZxid = 0x10000000b
cversion = 4
dataVersion = 0
aclVersion = 0
ephemeralOwner = 0x0
dataLength = 4
numChildren = 2(2)在Hadoop103主机上修改
/simon节点的数据[zk: localhost:2181(CONNECTED) 0] set /simon "hello world"
cZxid = 0x100000004
ctime = Thu Oct 24 21:59:31 CST 2019
mZxid = 0x100000015
mtime = Thu Oct 24 22:29:32 CST 2019
pZxid = 0x10000000b
cversion = 4
dataVersion = 1
aclVersion = 0
ephemeralOwner = 0x0
dataLength = 11
numChildren = 2(3)在Hadoop104节点上观察数据的变化的监听
[zk: localhost:2181(CONNECTED) 1]
WATCHER:: WatchedEvent state:SyncConnected type:NodeDataChanged path:/simon节点的子节点变化监听(路劲变化)
(1)在Hadoop104主机上注册监听
/simon节点的子节点变化[zk: localhost:2181(CONNECTED) 0] ls /simon watch
[a, b](2)在Hadoop103主机
/simon节点创建子节点[zk: localhost:2181(CONNECTED) 4] create /simon/c "c"
Created /simon/c(3)观察Hadoop104主机收到的子节点变化的监听
[zk: localhost:2181(CONNECTED) 4] ls /simon watch
WATCHER:: WatchedEvent state:SyncConnected type:NodeChildrenChanged path:/simon删除节点
[zk: localhost:2181(CONNECTED) 6] delete /simon/b/bd递归删除节点
[zk: localhost:2181(CONNECTED) 7] rmr /simon/b查看节点的状态
[zk: localhost:2181(CONNECTED) 8] stat /simon
cZxid = 0x100000004
ctime = Thu Oct 24 21:59:31 CST 2019
mZxid = 0x100000015
mtime = Thu Oct 24 22:29:32 CST 2019
pZxid = 0x100000021
cversion = 6
dataVersion = 1
aclVersion = 0
ephemeralOwner = 0x0
dataLength = 11
numChildren = 2
ZooKeeper学习笔记(四)——shell客户端命令操作的更多相关文章
- ZooKeeper学习笔记四:使用ZooKeeper实现一个简单的分布式锁
作者:Grey 原文地址: ZooKeeper学习笔记四:使用ZooKeeper实现一个简单的分布式锁 前置知识 完成ZooKeeper集群搭建以及熟悉ZooKeeperAPI基本使用 需求 当多个进 ...
- Zookeeper学习笔记——2 Shell和Java API的使用
ZooKeeper的使用一般都接触不到,因为平时工作甚少直接使用ZK.但是通过手动操作一下ZK,还是能对其中的门道了解各一二. shell 常用命令 help 查看所有支持的命令 [zk: local ...
- SQL学习笔记四之MySQL数据操作
阅读目录 一 介绍 二 插入数据INSERT 三 更新数据UPDATE 四 删除数据DELETE 五 查询数据SELECT 六 权限管理 一 介绍 MySQL数据操作: DML =========== ...
- 吴裕雄--天生自然ShellX学习笔记:Shell test 命令
Shell中的 test 命令用于检查某个条件是否成立,它可以进行数值.字符和文件三个方面的测试. 实例演示: num1=100 num2=100 if test $[num1] -eq $[num2 ...
- 吴裕雄--天生自然ShellX学习笔记:Shell printf 命令
printf 命令模仿 C 程序库(library)里的 printf() 程序. printf 由 POSIX 标准所定义,因此使用 printf 的脚本比使用 echo 移植性好. printf ...
- 吴裕雄--天生自然ShellX学习笔记:Shell echo命令
Shell 的 echo 指令与 PHP 的 echo 指令类似,都是用于字符串的输出.命令格式: echo string 您可以使用echo实现更复杂的输出格式控制. 1.显示普通字符串: echo ...
- ELK学习笔记之使用curl命令操作elasticsearch
0x00 _cat系列 _cat系列提供了一系列查询elasticsearch集群状态的接口.你可以通过执行curl -XGET localhost:9200/_cat 1. 获取所有_cat系列的操 ...
- CMake学习笔记四-CMake常用命令
CMake常用命令 PROJECT PROJECT(projectname [CXX] [C] [Java]) 指定工程名称,并可指定工程支持的语言.支持语言列表可忽略,默认支持所有语言 SET ...
- RabbitMQ学习笔记四:RabbitMQ命令(附疑难问题解决)
本来今天是想做RabbitMQ之优先级队列的,但是,在RabbitMQ Server创建queue时,增加优先级的最大值,头脑发热写了9999999,导致电脑内存直接飙到100%,只能重启电脑,并卸载 ...
随机推荐
- 部署gerrit环境完整记录【转】
开发同事提议在线上部署一套gerrit代码审核环境,废话不多说,部署gerrit的操作记录如下:提前安装好java环境,mysql环境,nginx环境测试系统:centos6.5下载下面三个包,放到/ ...
- Javascript事件派发-dispatchEvent
事件派发的作用: 1.派发数据,将一个封闭模块中的数据传递给另一个封闭模块.2.事件完成了较为复杂的解耦. 事件和回调函数不同在于: 1.事件可以在任意地方去获取,而回调函数只能在一个地方存在,如果需 ...
- 移动端IM系统的协议选型:UDP还是TCP?(转)
源: 移动端IM系统的协议选型:UDP还是TCP?
- 【linux】gitlab 的安装以及数据迁移
一 .安装; 1 下载相应版本rpm包并安装 https://mirrors.tuna.tsinghua.edu.cn/gitlab-ce/yum/el7/ wget https://mirrors ...
- 编译安装hls协议切片工具 m3u8-segmenter
操作系统:Ubuntu16.04.4 amd64 安装http://m3u8-segmenter.inodes.org/方式安装m3u8-segmenter报错,于是有了这篇文章 apt instal ...
- LwIP应用开发笔记之一:LwIP无操作系统基本移植
现在,TCP/IP协议的应用无处不在.随着物联网的火爆,嵌入式领域使用TCP/IP协议进行通讯也越来越广泛.在我们的相关产品中,也都有应用,所以我们结合应用实际对相关应用作相应的总结. 1.技术准备 ...
- docker外部执行容器内部命令
docker exec jenkins 'cat /var/jenkins_home/secrets/initialAdminPassword'
- kubernetes 【版本】
kubernetes本身是一个集群,我们所说的kubernetes版本实际上指的是集群各个组件的版本. 有哪些组件有版本呢? https://kubernetes.io/docs/setup/rele ...
- node.js http-server 搭建本地服务器
使用vue-cli创建的项目,能够实现浏览器中自动刷新,实时查看项目效果,其中的原理在于,webpack在本地启动了一个本地服务器,将本机当作一台服务器: 打包后的文件是一个html静态页面,在本地文 ...
- nodejs实现一个文件存储服务
nodejs实现一个文件存储服务 模拟文件上传下载功能: PUT 上传一个文件,URL表示在服务器上待上传文件的路径. GET 下载一个文件,URL表示在服务器上待下载文件的路径.