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结构
原文链接:https://www.cnblogs.com/summerday152/p/14012622.html
如果觉得本文对你有帮助,可以点赞关注支持一下,也可以点进我主页关注我公众号,上面有更多技术干货文章以及相关资料共享,大家一起学习进步!