使用docker镜像搭建简单的zookeeper集群

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
  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
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`命令来查看容器的运行状态。 请注意,上述示例中的配置仅适用于演示目的。在实际生产环境中,你可能需要进行更多的配置和优化,例如设置数据持久化、配置节点间的通信安全等。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值