docker搭建Zookeeper集群的方法步骤

 更新时间:2022年05月25日 14:30:46   作者:其乐无穷5423  
本文主要介绍了docker搭建Zookeeper集群的方法步骤,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

0.前言

之前在学springcloud的时候,提到有些项目还是使用zookeeper作为注册中心。

因此决定掌握这个技能,但是本地为了测试而部署一套zookeeper集群还是比较麻烦的。

所以打算使用docker在本地上搭建zookeeper集群

1.前提

  • 电脑里安装过docker
  • 了解部分docker命令

2.开始搭建

准备好一个空目录,需要建3个文件夹,然后每个文件夹里面建2个文件,如下所示:

.
├── zk1 (文件夹)
│   ├── myid (文件)
│   └── zoo.cfg (文件)
├── zk2(文件夹)
│   ├── myid(文件)
│   └── zoo.cfg(文件)
└── zk3(文件夹)
    ├── myid(文件)
    └── zoo.cfg(文件)

解释

文件 文件里面内容
zk1/myidZookeeper第一个节点的id配置,只需要一个数字100
zk1/zoo.cfgZookeeper第一个节点的配置信息之后有个例子
zk2/myidZookeeper第二个节点的id配置,只需要一个数字200
zk2/zoo.cfgZookeeper第二个节点的配置信息之后有个例子
zk3/myidZookeeper第三个节点的id配置,只需要一个数字300
zk3/zoo.cfgZookeeper第三个节点的配置信息之后有个例子

创建zoo.cfg

3个zoo.cfg里面内容是一样的,如下所示

tickTime=2000
initLimit=10
syncLimit=5
dataDir=/zkData
clientPort=2181
​
server.100=127.0.0.1:2888:3888
server.200=127.0.0.1:2888:3888
server.300=127.0.0.1:2888:3888

比较奇怪的是最后3行,这3行也是这个集群能否创建的关键

server.100=127.0.0.1:2888:3888
server.200=127.0.0.1:2888:3888
server.300=127.0.0.1:2888:3888

他们都形如

server.A=B:C:D

具体含义如下

参数含义
server常量,这个不用改
A就是myid,在【开始搭建】的【解释】里提到过的数字
B服务器地址,因为都是本地环境搭建的,就是127.0.0.1
C信息交互端口,不用改,就2888挺好
D选举端口,不用改,就3888挺好

3.docker搭建

当3个文件夹,6个目录创建好了以后,就可以使用命令进行搭建了

1.docker创建网络

创建docker网络,是为了保证3个容器可以互相通信

命令如下:其中network-zk-nb是自己取的,后面创建容器时会用到

docker network create network-zk-nb

2.启动第1个zk节点

如果是linux或mac

docker run -d --name  zk1 \
--restart always  \
-e JVMFLAGS="-Xmx1024m" \
-v /Users/admin/env/zk/zk1/zoo.cfg:/conf/zoo.cfg \
-v /Users/admin/env/zk/zk1/myid:/data/myid \
--network network-zk-nb --network-alias zk1 \
-p 2181:2181   zookeeper:3.5.7

如果是windows,那么就改为

docker run -d --name  zk1 ^
--restart always  ^
-e JVMFLAGS="-Xmx1024m" ^
-v ./zk1/zoo.cfg:/conf/zoo.cfg ^
-v ./zk1/zoo.cfg:/data/myid ^
--network network-zk-nb --network-alias zk1 ^
-p 2181:2181   zookeeper:3.5.7

PS:因为里面用到了./,也就是相对目录,所以你必须要在3个目录所在的目录下才能使用这条命令

3.启动第2个zk节点

docker run -d --name  zk2 \
--restart always  \
-e JVMFLAGS="-Xmx1024m" \
-v /Users/admin/env/zk/zk2/zoo.cfg:/conf/zoo.cfg \
-v /Users/admin/env/zk/zk2/myid:/data/myid \
--network network-zk-nb --network-alias zk2 \
-p 2182:2181   zookeeper:3.5.7

4.启动第3个zk节点

docker run -d --name  zk3 \
--restart always  \
-e JVMFLAGS="-Xmx1024m" \
-v /Users/admin/env/zk/zk3/zoo.cfg:/conf/zoo.cfg \
-v /Users/admin/env/zk/zk3/myid:/data/myid \
--network network-zk-nb --network-alias zk3 \
-p 2183:2181   zookeeper:3.5.7

至此zookeeper的集群环境搭建完毕

4.访问节点

1.进入zk第一个节点的docker容器内部

docker exec -it zk1 /bin/bash

查看容器目录

ls -l 
-rw-r--r-- 1 zookeeper zookeeper 11358 Sep 13  2018 LICENSE.txt
-rw-r--r-- 1 zookeeper zookeeper   432 Feb 10  2020 NOTICE.txt
-rw-r--r-- 1 zookeeper zookeeper  1560 Feb  7  2020 README.md
-rw-r--r-- 1 zookeeper zookeeper  1347 Feb  7  2020 README_packaging.txt
drwxr-xr-x 2 zookeeper zookeeper  4096 Feb 10  2020 bin
drwxr-xr-x 2 zookeeper zookeeper  4096 May 16  2020 conf
drwxr-xr-x 5 zookeeper zookeeper  4096 Feb 10  2020 docs
drwxr-xr-x 2 zookeeper zookeeper  4096 May 16  2020 lib

进入bin目录

cd bin

查看bin目录

ls -l
total 56
-rwxr-xr-x 1 zookeeper zookeeper  232 May  4  2018 README.txt
-rwxr-xr-x 1 zookeeper zookeeper 2067 Feb  7  2020 zkCleanup.sh
-rwxr-xr-x 1 zookeeper zookeeper 1158 Feb 10  2020 zkCli.cmd
-rwxr-xr-x 1 zookeeper zookeeper 1621 Feb  7  2020 zkCli.sh
-rwxr-xr-x 1 zookeeper zookeeper 1766 Feb  7  2020 zkEnv.cmd
-rwxr-xr-x 1 zookeeper zookeeper 3690 Jan 31  2020 zkEnv.sh
-rwxr-xr-x 1 zookeeper zookeeper 4573 Feb  7  2020 zkServer-initialize.sh
-rwxr-xr-x 1 zookeeper zookeeper 1286 Jan 31  2020 zkServer.cmd
-rwxr-xr-x 1 zookeeper zookeeper 9386 Feb  7  2020 zkServer.sh
-rwxr-xr-x 1 zookeeper zookeeper  996 Oct  3  2019 zkTxnLogToolkit.cmd
-rwxr-xr-x 1 zookeeper zookeeper 1385 Feb  7  2020 zkTxnLogToolkit.sh

2.使用zk的客户端进行访问

zkCli.sh
WatchedEvent state:SyncConnected type:None path:null
[zk: localhost:2181(CONNECTED) 0] 

3.在zk中使用命令

ls /

至此,zk集群的搭建与使用就已经完成,后面学习的就是使用java的方式来连接

到此这篇关于docker搭建Zookeeper集群的方法步骤的文章就介绍到这了,更多相关docker搭建Zookeeper集群内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Docker移除镜像几种不同的方法实战记录

    Docker移除镜像几种不同的方法实战记录

    在Docker实战中,合理删除不再需要的镜像,有助于释放宝贵的磁盘空间,删除Docker镜像可以通过多种方式,包括删除单个镜像、强制删除正在使用的镜像、删除未被任何容器引用的所有镜像以及删除所有镜像等,需要的朋友可以参考下
    2024-11-11
  • Docker部署及使用压测神器sysbench的方法

    Docker部署及使用压测神器sysbench的方法

    sysbench 是一个开源跨平台的多线程性能测试工具,这篇文章主要介绍了Docker部署及使用压测神器sysbench的相关知识,需要的朋友可以参考下
    2022-08-08
  • Docker Buildx 简介与安装指南(最新推荐)

    Docker Buildx 简介与安装指南(最新推荐)

    Docker Buildx 是 Docker 官方推出的一款增强型构建工具,旨在简化和优化多架构容器映像的构建流程,这篇文章主要介绍了Docker Buildx 简介与安装指南,需要的朋友可以参考下
    2024-08-08
  • Docker+K8S 集群环境搭建及分布式应用部署

    Docker+K8S 集群环境搭建及分布式应用部署

    这篇文章主要介绍了Docker+K8S 集群环境搭建及分布式应用部署,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-07-07
  • Docker中部署nginx服务的方案

    Docker中部署nginx服务的方案

    这篇文章主要介绍了Docker中部署nginx服务的方案的相关资料,需要的朋友可以参考下
    2022-11-11
  • Docker安装阿里云服务器和在虚拟机安装遇到的坑(问题小结)

    Docker安装阿里云服务器和在虚拟机安装遇到的坑(问题小结)

    这篇文章主要介绍了Docker安装阿里云服务器和在虚拟机安装遇到的坑,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-03-03
  • docker部署springboot和vue项目的实现步骤

    docker部署springboot和vue项目的实现步骤

    本文主要介绍了docker部署springboot和vue项目的实现步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-06-06
  • 解决docker拉取镜像报错:error pulling image configuration:(kafka)

    解决docker拉取镜像报错:error pulling image configurat

    在使用Docker拉取Kafka镜像时可能会遇到"error pulling image configuration"的错误,这可以通过编辑Docker配置文件并重启Docker服务来解决,具体步骤包括:1. 编辑Docker配置文件;2. 使用命令systemctl restart docker重启Docker服务
    2024-11-11
  • 树莓派系列之使用docker安装青龙面板和改端口号的配置问题

    树莓派系列之使用docker安装青龙面板和改端口号的配置问题

    这篇文章主要介绍了树莓派系列之使用docker安装青龙面板和改端口号的问题,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-02-02
  • Docker如何实现离线安装

    Docker如何实现离线安装

    文章介绍了如何在离线环境中安装Docker,并将其注册为系统服务,主要内容包括下载Docker二进制文件、上传到服务器、解压安装包、配置系统服务以及验证安装是否成功
    2024-11-11

最新评论