Docker安装Zookeeper
下载并运行
$ docker search zookeeper # 查看一下镜像
$ docker pull zookeeper:3.4.9 # 拉取指定版本zk镜像
$ docker images # 查看image ID
$ mkdir -p /root/docker/zookeeper/data
$ docker run -d -p 2181:2181 -v /root/docker/zookeeper/data:/data/ --name zookeeper --privileged 3b83d9104a4c # 最后跟着 image ID
进入容器
$ docker ps # 查看zookeeper的CONTAINER ID
$ docker exec -it CONTAINERID /bin/bash # 后台进入容器
连接ZooKeeper 服务
$ cd bin # 进入bin目录
$ ./zkCli.sh
设置防火墙
关于防火墙,你可以关闭它,或者开启2181端口:
【查看防火墙是否开启】
$ systemctl status firewalld
【开启或关闭防火墙】
$ systemctl start firewalld
$ systemctl stop firewalld
【查看所有开启的端口】
$ firewall-cmd --list-ports
【开启80端口】
$ firewall-cmd --zone=public --add-port=2181/tcp --permanent
【重启防火墙,使其生效】
$ firewall-cmd --reload
配置阿里云安全组
来到实例管理页面,点击更多,点击网络和安全组,点击安全组配置。
点击配置规则。
点击添加安全组规则
使用Zookeeper图形化客户端工具连接
下载地址:https://issues.apache.org/jira/secure/attachment/12436620/ZooInspector.zip
解压压缩包,进入jar包所在目录,执行命令:
$ java -jar xxx.jar
左上角按钮表示登录,主机地址和端口号:你的服务器ip:2181
Docker常用命令演示
查看常用命令help
[zk: localhost:2181(CONNECTED) 0] help
创建节点create
通过 create
命令在根目录创建了 node1 节点,与它关联的字符串是"node1"
[zk: localhost:2181(CONNECTED) 0] create /node1 "node1"
通过 create
命令在根目录创建了 /node1/node1.1 节点,与它关联的内容是数字 123
[zk: localhost:2181(CONNECTED) 0] create /node1/node1.1 123
设置节点数据内容set
设置/node1节点的数据内容为"new node!",此时相当于更新操作。
[zk: localhost:2181(CONNECTED) 0] set /node1 "new node!"
获取节点的数据get
get
命令可以获取指定节点的数据内容和节点的状态,可以看出我们通过 set
命令已经将节点数据内容改为 "new node!"。
[zk: localhost:2181(CONNECTED) 0] get /node1 #"new node!"
cZxid = 0xb
ctime = Fri Nov 20 09:36:43 GMT 2020
mZxid = 0xd
mtime = Fri Nov 20 09:43:25 GMT 2020
pZxid = 0x10
cversion = 2
dataVersion = 1
aclVersion = 0
ephemeralOwner = 0x0
dataLength = 9
numChildren = 0
下面的一些字段信息,将在本篇第三节znode结构中介绍。
查看某个目录的子节点ls
查看根目录下的子节点
[zk: localhost:2181(CONNECTED) 0] ls /
[node2, zookeeper, node1]
查看/node1目录下的子节点
[zk: localhost:2181(CONNECTED) 0] ls /node1
[node1.1]
查看节点状态stat
[zk: localhost:2181(CONNECTED) 0] stat /node1
cZxid = 0xb
ctime = Fri Nov 20 09:36:43 GMT 2020
mZxid = 0xd
mtime = Fri Nov 20 09:43:25 GMT 2020
pZxid = 0xc
cversion = 1
dataVersion = 1
aclVersion = 0
ephemeralOwner = 0x0
dataLength = 9
numChildren = 1
查看节点信息和状态ls2
ls2 = ls + stat
[zk: localhost:2181(CONNECTED) 0] ls2 /node1
[node1.1]
cZxid = 0xb
ctime = Fri Nov 20 09:36:43 GMT 2020
mZxid = 0xd
mtime = Fri Nov 20 09:43:25 GMT 2020
pZxid = 0xc
cversion = 1
dataVersion = 1
aclVersion = 0
ephemeralOwner = 0x0
dataLength = 9
numChildren = 1
删除节点delete
删除某一个节点,这个节点必须无子节点。
[zk: localhost:2181(CONNECTED) 10] delete /node1
Node not empty: /node1
[zk: localhost:2181(CONNECTED) 11] delete /node1/node1.1
[zk: localhost:2181(CONNECTED) 12] get /node1/node1.1
Node does not exist: /node1/node1.1
znode结构
znode 状态信息 | 解释 |
---|---|
cZxid | create ZXID,即该数据节点被创建时的事务 id |
ctime | create time,即该节点的创建时间 |
mZxid | modified ZXID,即该节点最终一次更新时的事务 id |
mtime | modified time,即该节点最后一次的更新时间 |
pZxid | 该节点的子节点列表最后一次修改时的事务 id,只有子节点列表变更才会更新 pZxid,子节点内容变更不会更新 |
cversion | 子节点版本号,当前节点的子节点每次变化时值增加 1 |
dataVersion | 数据节点内容版本号,节点创建时为 0,每更新一次节点内容(不管内容有无变化)该版本号的值增加 1 |
aclVersion | 节点的 ACL 版本号,表示该节点 ACL 信息变更次数 |
ephemeralOwner | 创建该临时节点的会话的 sessionId;如果当前节点为持久节点,则 ephemeralOwner=0 |
dataLength | 数据节点内容长度 |
numChildren | 当前节点的子节点个数 |