zookeeper集群_docker环境,搭建zookeeper集群

564806d551b5d3a10a0f4fcfae44a57e.png

这篇文章分享如何在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

如果您觉得本文不错,欢迎关注我的微信公众号,您的关注是我坚持的动力!

e992ce8f0207c08e1beca4c87572a87d.png
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Docker搭建ZooKeeper集群可以通过以下步骤完成: 1. 创建一个用于存储ZooKeeper配置文件和数据的目录,例如`/path/to/zookeeper-data`。 2. 创建一个`docker-compose.yml`文件来定义ZooKeeper集群的配置。示例如下: ```yaml version: '3' services: zookeeper1: image: zookeeper restart: always hostname: zookeeper1 ports: - "2181:2181" environment: ZOO_MY_ID: 1 ZOO_SERVERS: server.1=zookeeper1:2888:3888 server.2=zookeeper2:2888:3888 server.3=zookeeper3:2888:3888 volumes: - /path/to/zookeeper-data:/data zookeeper2: image: zookeeper restart: always hostname: zookeeper2 environment: ZOO_MY_ID: 2 ZOO_SERVERS: server.1=zookeeper1:2888:3888 server.2=zookeeper2:2888:3888 server.3=zookeeper3:2888:3888 volumes: - /path/to/zookeeper-data:/data zookeeper3: image: zookeeper restart: always hostname: zookeeper3 environment: ZOO_MY_ID: 3 ZOO_SERVERS: server.1=zookeeper1:2888:3888 server.2=zookeeper2:2888:3888 server.3=zookeeper3:2888:3888 volumes: - /path/to/zookeeper-data:/data ``` 在上述配置中,我们使用了ZooKeeper官方提供的Docker镜像,并定义了三个服务,每个服务对应一个ZooKeeper节点。`ZOO_MY_ID`环境变量用于指定每个节点的ID,`ZOO_SERVERS`环境变量用于指定集群中所有节点的地址和端口。 3. 运行`docker-compose up -d`命令启动ZooKeeper集群。 运行成功后,你将获得一个包含三个ZooKeeper节点的集群。你可以使用`docker-compose ps`命令来查看容器的运行状态。 请注意,上述示例中的配置仅适用于演示目的。在实际生产环境中,你可能需要进行更多的配置和优化,例如设置数据持久化、配置节点间的通信安全等。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值