Docker部署Zookeeper分布式协调器的实现
作者:菜鸟厚非
一、简介
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 内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!