在Docker中启动zookeeper模拟集群

这里我们将会使用docker-componse来启动3个zookeeper容器;

1.先下载好zookeeper的镜像docker pull zookeeper.

2.创建一个目录,在该目录下新建docker-componse.yml文件,内容如下:

version: '3.1'
services:
  zoo1:
    image: zookeeper
    restart: always
    hostname: zoo1
    ports:
      - 2181:2181
    environment:
      ZOO_MY_ID: 1
      ZOO_SERVERS: server.1=zoo1:2888:3888 server.2=zoo2:2888:3888 server.3=zoo3:2888:3888

  zoo2:
    image: zookeeper
    restart: always
    hostname: zoo2
    ports:
      - 2182:2181
    environment:
      ZOO_MY_ID: 2
      ZOO_SERVERS: server.1=zoo1:2888:3888 server.2=zoo2:2888:3888 server.3=zoo3:2888:3888

  zoo3:
    image: zookeeper
    restart: always
    hostname: zoo3
    ports:
      - 2183:2181
    environment:
      ZOO_MY_ID: 3
      ZOO_SERVERS: server.1=zoo1:2888:3888 server.2=zoo2:2888:3888 server.3=zoo3:2888:3888

其中:
2181端口号是客户端连接zookeeper集群监听的端口号,
3888是选举leader使用的端口号,
2888是集群内通讯使用,leader和follower之间数据同步使用的端口号,leader监听此端口号.

3.在该目录下启动命令行,运行docker-componse up -d启动这三个容器:
image.png

4.运行docker ps查看启动的容器:
image.png

5.以交互式的方式进入某个容器exec -it zookeeper_zoo3_1 /bin/bash,
并进入cd bin/目录,查看容器的状态./zkServer.sh status:
image.png

6.再进入cd /conf/目录,运行cat zoo.cfg查看zookpeeper容器的配置信息:
image.png
其中:
clientPort就是zookeeper服务端监听客户端的端口,
dataDir目录是数据存放的目录,并且在/data下的myid文件中定义了zookeeper服务的id编号,
也就是server.id

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 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、付费专栏及课程。

余额充值