这篇文章分享如何在docker环境下搭建zookeeper集群。
bin/jdk:8u221镜像的构建,请参考之前的文章 -- docker基础环境搭建
下载apache-zookeeper-3.5.7-bin.tar.gz,并构建bin/zookeeper:3.5.7镜像,Dockerfile如下
FROM bin/jdk:8u221
WORKDIR /usr/lib
COPY apache-zookeeper-3.5.7-bin.tar.gz .
RUN tar -xzf apache-zookeeper-3.5.7-bin.tar.gz && rm apache-zookeeper-3.5.7-bin.tar.gz
COPY docker-entrypoint.sh /usr/local/bin
RUN groupadd -r zookeeper && useradd -r -g zookeeper zookeeper \
&& chmod 777 /usr/local/bin/docker-entrypoint.sh
VOLUME /usr/local/zookeeper/data/
WORKDIR /usr/lib/apache-zookeeper-3.5.7-bin
ENTRYPOINT ["docker-entrypoint.sh"]
docker-entrypoint.sh负责编写配置文件,启动zookeeper进程
#!/bin/bash
if [ -z "$PORT" ]; then
PORT=2181
fi
cat>>conf/zoo.cfg<<EOF
tickTime=2000
initLimit=10
syncLimit=5
clientPort=$PORT
dataDir=/usr/local/zookeeper/data
EOF
if [ -n "$SERVER_ID" ]; then
echo $SERVER_ID >> /usr/local/zookeeper/data/myid
fi
if [ -n "$SERVER_GROUP" ]; then
for server in ${SERVER_GROUP[@]}; do
echo "$server" >>conf/zoo.cfg
done
fi
chown -R zookeeper:zookeeper /usr/local/zookeeper/data
exec gosu zookeeper bin/zkServer.sh start-foreground
exec bin/zkServer.sh start-foreground
使用前台进程运行zookeeper,因为Docker容器仅在它的1号进程(PID为1)运行时,会保持运行。如果1号进程退出了(或者转为后台运行),Docker容器也就退出了。
zookeeper集群需要在dataDir目录下创建myid文件,写入SERVER_ID,而且需要在配置文件中写入每个集群成员的网络信息。docker-entrypoint.sh中将SERVER_GROUP变量按空格分割,将分隔后的分割写入到配置文件中。
编写一个docker-bin.sh,负责启动docker容器
#!/bin/bash
# 用空格连接集群成员网络信息
server_group='';
for i in `seq 1 3`; do
server_group="${server_group}server.${i}=zk-${i}:2281:22281 "
done
# 删除server_group最后一个空格
server_group=${server_group%?}
sudo docker network create zk-net
for i in `seq 1 3`; do
sudo docker run -d --name zk-${i} --network zk-net --network-alias zk-$i \
-e SERVER_ID=$i -e SERVER_GROUP="$server_group" bin/zookeeper:3.5.7
done
可以看到,写入配置文件的集群成员网络信息格式如下server.(SERVER_ID)=(IP):(PORT1):(PORT2)
。
其中第一个端口用来集群成员之间交换信息以及与Leader 服务器交换信息,第二个端口是在Leader不可用时专门用来选举新Leader的。
通过以下命令查看集群成员的状态
sudo docker exec zk-1 bin/zkServer.sh status
如果您觉得本文不错,欢迎关注我的微信公众号,您的关注是我坚持的动力!
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。