Docker部署Zookeeper分布式协调器的实现

 更新时间:2024年11月07日 10:41:36   作者:菜鸟厚非  
Zookeeper是分布式数据一致性的关键技术,支持单机和集群部署,集群部署需奇数节点,,通过Docker部署方便,支持配置文件映射和动态角色变更,感兴趣的可以了解一下

一、简介

Zookeeper 是一个开源的分布式协调器,是一个典型的分布式数据一致性解决方案,其设计目的是将复杂且容易出错的分布式一致性服务封装起来,构成一个高效可靠的系统,并以一系列简单易用的原子操作提供给用户使用。

二、部署

Zookeeper 支持单机和集群部署,集群部署时,节点个数需要部署为奇数个。这里安装的是 3.8.4 Tag版本,如果需要安装其他或者最新版本,可以到 Docker Hub 进行查找。

2.1 单节点部署

docker run -d `
-p 2181:2181 -p 2888:2888 -p 3888:3888 `
--restart always `
--name zookeeper-3.8.4 `
-v C:\ProgramDatas\Docker\Containers\zookeeper-3.8.4\data:/data `
-v C:\ProgramDatas\Docker\Containers\zookeeper-3.8.4\datalog:/datalog `
zookeeper:3.8.4

-zookeeper 常用的三个端口。2181 端口主要用于对客户端提供服务、3888 端口主要用于选举leader、2888 端口主要用于集群内机器通讯,特别是在 Leader 监听此端口。
-参数 -v C:\ProgramDatas\Docker\Containers\zookeeper-3.8.4\data:/data 内存中的数据库快照。
-参数 -v C:\ProgramDatas\Docker\Containers\zookeeper-3.8.4\datalog:/datalog 更新数据的事务日志。

2.2 集群部署

集群部署,这里以 zookeeper1-3.8.4、zookeeper2-3.8.4、zookeeper3-3.8.4 三台为例。

docker network create zookeeper-net
docker run -d `
-p 2181:2181 -p 2888:2888 -p 3888:3888 `
--restart always `
--name zookeeper1-3.8.4 `
--network=zookeeper-net `
-e ZOO_MY_ID="1" `
-e ZOO_SERVERS="server.1=zookeeper1-3.8.4:2888:3888;2181 server.2=zookeeper2-3.8.4:2889:3889;2182 server.3=zookeeper3-3.8.4:2890:3890;2183" `
-v C:\ProgramDatas\Docker\Containers\zookeeper1-3.8.4\data:/data `
-v C:\ProgramDatas\Docker\Containers\zookeeper1-3.8.4\datalog:/datalog `
zookeeper:3.8.4
docker run -d -p 2182:2181 -p 2889:2888 -p 3889:3888 `
--restart always `
--name zookeeper2-3.8.4 `
--network=zookeeper-net `
-e ZOO_MY_ID="2" -e ZOO_SERVERS="server.1=zookeeper1-3.8.4:2888:3888;2181 server.2=zookeeper2-3.8.4:2889:3889;2182 server.3=zookeeper3-3.8.4:2890:3890;2183" `
-v C:\ProgramDatas\Docker\Containers\zookeeper2-3.8.4\data:/data `
-v C:\ProgramDatas\Docker\Containers\zookeeper2-3.8.4\datalog:/datalog `
zookeeper:3.8.4
docker run -d `
-p 2813:2181 -p 2890:2888 -p 3890:3888 `
--restart always `
--network=zookeeper-net `
-e ZOO_MY_ID="3" `
-e ZOO_SERVERS="server.1=zookeeper1-3.8.4:2888:3888;2181 server.2=zookeeper2-3.8.4:2889:3889;2182 server.3=zookeeper3-3.8.4:2890:3890;2183" `
-v C:\ProgramDatas\Docker\Containers\zookeeper3-3.8.4\data:/data `
-v C:\ProgramDatas\Docker\Containers\zookeeper3-3.8.4\datalog:/datalog `
--name zookeeper3-3.8.4 `
zookeeper:3.8.4

部署完成后,使用命令 ./bin/zkServer.sh status 分别进去三个 Zookeeper,查看每台分别处于什么角色(leader、follower)。

可以看到 zookeeper3-3.8.4 是 leader,zookeeper1-3.8.4、zookeeper2-3.8.4 是 follower。可以扩展测一下,把 zookeeper3-3.8.4 关闭,然后再看一下 zookeeper1-3.8.4、zookeeper2-3.8.4 是否正常进行了选举。

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述


在这里插入图片描述

三、连接 Zookeeper

使用 PrettyZoo 软件(或者 ZooKeeper Assistant、zkdash、zkui、ZooInspector)连接 Zookeeper,地址使用 127.0.0.1 端口为 2181,默认没有用户名与密码。看到如下,Docker 中的 Zookeeper 即代表部署成功。

在这里插入图片描述

在这里插入图片描述

四、配置映射

如果需要配置 zookeeper 的话,会用到 zoo.cfg 配置文件。容器版本的 Zookeeper 在执行启动命令后,会将命令中的一些信息,写入到容器内 /conf/zoo.cfg 文件中(端口、ID 等信息)。所以,需要将容器内的 /conf/zoo.cfg 文件拷贝到物理机,并进行映射。

为了方便,可以将整个 /conf 文件夹拷贝到物理机,并进行映射。

4.1 单机

  • 使用下面命令,把容器内的 /conf 文件夹拷贝的物理机,然后停止并删除容器。
docker cp zookeeper-3.8.4:/conf C:\ProgramDatas\Docker\Containers\zookeeper-3.8.4\conf
docker stop zookeeper-3.8.4
docker rm zookeeper-3.8.4
  • 重新部署容器,在启动容器的命令中,加一条 -v 参数进行路径的映射。
-v C:\ProgramDatas\Docker\Containers\zookeeper-3.8.4\conf:/conf

4.2 集群

如果部署的是个集群,拷贝容器内的 /conf 文件夹到物理机,需要从每个节点对应部署命令启动的容器中进行拷贝不可以使用同一个容器内的 /conf 文件夹中的配置文件。

到此这篇关于Docker部署Zookeeper分布式协调器的实现的文章就介绍到这了,更多相关Docker部署Zookeeper 内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 使用docker搭建redis主从的方法步骤

    使用docker搭建redis主从的方法步骤

    这篇文章主要介绍了使用docker搭建redis主从的方法步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-01-01
  • maven构建docker镜像push到镜像仓库方式

    maven构建docker镜像push到镜像仓库方式

    这篇文章主要介绍了maven构建docker镜像push到镜像仓库方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-11-11
  • Docker Compose引用环境变量的方法示例

    Docker Compose引用环境变量的方法示例

    在项目中,往往需要在 docker-compose.yml 文件中使用环境变量来控制不同的条件和使用场景。本文集中介绍 docker compose 引用环境变量的方式,感兴趣的小伙伴们可以参考一下
    2018-12-12
  • Docker中限制CPU和内存的使用的方法

    Docker中限制CPU和内存的使用的方法

    在容器化的动态世界中,Docker 已经成为构建、部署和管理容器化的关键工具应用,设置适当的内存和 CPU 限制对于优化 Docker 性能至关重要,确保每个容器在不使主机负担过重的情况下获得必要的资源,本文将深入探讨有效设置这些限制的实用策略,需要的朋友可以参考下
    2025-01-01
  • docker容器运行后退出(怎么才能一直运行)

    docker容器运行后退出(怎么才能一直运行)

    这篇文章主要介绍了docker容器运行后退出(怎么才能一直运行),本文详细的介绍了解决方法,非常具有实用价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-01-01
  • 六种Docker目录挂载类型及注意事项总结

    六种Docker目录挂载类型及注意事项总结

    这篇文章主要介绍了六种Docker目录挂载方式,包括数据卷挂载、绑定挂载、临时文件系统挂载、命名卷挂载、匿名卷挂载和卷驱动挂载,并详细说明了每种挂载方式的定义、举例和注意事项,需要的朋友可以参考下
    2025-03-03
  • Docker-Compose搭建Spark集群的实现方法

    Docker-Compose搭建Spark集群的实现方法

    本文主要介绍了Docker-Compose搭建Spark集群的实现方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-05-05
  • 基于docker搭建redis集群的方法

    基于docker搭建redis集群的方法

    这篇文章主要介绍了基于docker搭建redis集群的方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-12-12
  • vscode利用ssh配置docker容器并开启远程编程模式的详细步骤

    vscode利用ssh配置docker容器并开启远程编程模式的详细步骤

    这篇文章主要介绍了vscode利用ssh配置docker容器内开启远程编程模式,本文给大家讲解的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2023-03-03
  • docker-compose编排单体nacos、rabbitmq、redis基础服务详解

    docker-compose编排单体nacos、rabbitmq、redis基础服务详解

    这篇文章主要介绍了docker-compose编排单体nacos、rabbitmq、redis基础服务,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2025-04-04

最新评论