1、使用上一篇文章使用dockerfile搭建zookeeper基础环境生成的镜像作为基础的zookeeper环境
2、zookeeper的集群建议使用奇数台机器进行搭建,搭建一个简单的集群,最少需要3台机器,这里使用docker来模拟3台物理机:zk1、zk2、zk3
3、实现docker不同容器间互连,可以让3个容器在网络上,创建一个docker网络:
docker network create zk_net
4、启动3个容器
docker run -d -i -t --name zk1 -h zk1 -p 21811:2181 --network zk_net registry.cn-qingdao.aliyuncs.com/lankston/centos:zk
docker run -d -i -t --name zk2 -h zk2 -p 21812:2181 --network zk_net registry.cn-qingdao.aliyuncs.com/lankston/centos:zk
docker run -d -i -t --name zk3 -h zk3 -p 21813:2181 --network zk_net registry.cn-qingdao.aliyuncs.com/lankston/centos:zk
参数说明:
-d 后台运行容器并打印容器的ID
-i 保持STDIN开启即使没有链接
-h string:指定启动的容器的主机名(通过hostname命令查看),不指定默认主机名是容器ID
–network string:指定连接容器的网络
5、连接容器
docker exec -it zk1 /bin/bash
6、修改每台机器的zookeeper配置
进入zookeeper配置目录
cd /opt/zookeeper/zookeeper-3.4.13/conf/
修改配置文件:zoo.cfg,在文件zoo.cfg末尾添加:
server.1=zk1:2888:3888 server.2=zk2:2888:3888 server.3=zk3:2888:3888
在每台机器的zookeeper数据目录中创建myid文件:
cd /opt/zookeeper/data/ 机器1中:echo 1 > myid 机器2中:echo 2 > myid 机器3中:echo 3 > myid
7、启动zookeeper
/opt/zookeeper/zookeeper-3.4.13/bin/zkServer.sh start