docker zookeeper 集群搭建

前言node

其实zookeeper在通常的公司的应用不太多,注册中心、分布式锁、选举等等。以前用dubbo,就会用到zookeeper做为服务注册中心,如今转向springcloud,就不多用zookeeper了。可是近期研究分布式锁,对比了不少方案,好比数据库,redis,zookeeper等等,最终仍是选择zookeeper,至于缘由会在后续的文章中提到。
在开发环境中,你们应该都用的是zookeeper单点吧,可是在生产环境中我相信没有人敢用单点的,应该都是用的集群,由于万一单点挂掉的话,咱们的应用也就天然而然的ConnectionException。那么,接下来我就记录一下我本身用docker搭建zookeeper集群。redis

准备工具spring

1、安装docker
2、在docker库获取镜像:zookeeper(tips:我下载的版本是3.4.13)docker

搭建数据库

1、启动zookeeper单点,在开发环境中通常都用单点分布式

docker run -d -p 2181:2181 --restart always --name zookeeper \
-v $PWD/volume/data:/data \
-v $PWD/volume/datalog:/datalog \
zookeeper:3.4.13

2、zookeeper 集群搭建,这里我准备利用三个zookeeper节点组成一个集群,而且三个节点都在同一台主机上,若是须要节点原型在不一样的主机上,修改对应的ip和端口便可工具

-- 建立节点文件夹
mkdir cluster/node1 -p && mkdir cluster/node2 -p && mkdir cluster/node3 -p

-- 机器ip
machine_ip=10.82.12.95

-- 运行节点1
docker run -d -p 2181:2181 -p 2887:2888 -p 3887:3888 --name zookeeper_node1 --restart always \
-v $PWD/cluster/node1/volume/data:/data \
-v $PWD/cluster/node1/volume/datalog:/datalog \
-e "TZ=Asia/Shanghai" \
-e "ZOO_MY_ID=1" \
-e "ZOO_SERVERS=server.1=0.0.0.0:2888:3888 server.2=$machine_ip:2888:3888 server.3=$machine_ip:2889:3889" \
zookeeper:3.4.13

-- 运行节点2
docker run -d -p 2182:2181 -p 2888:2888 -p 3888:3888 --name zookeeper_node2 --restart always \
-v $PWD/cluster/node2/volume/data:/data \
-v $PWD/cluster/node2/volume/datalog:/datalog \
-e "TZ=Asia/Shanghai" \
-e "ZOO_MY_ID=2" \
-e "ZOO_SERVERS=server.1=$machine_ip:2887:3887 server.2=0.0.0.0:2888:3888 server.3=$machine_ip:2889:3889" \
zookeeper:3.4.13

-- 运行节点3
docker run -d -p 2183:2181 -p 2889:2888 -p 3889:3888 --name zookeeper_node3 --restart always \
-v $PWD/cluster/node3/volume/data:/data \
-v $PWD/cluster/node3/volume/datalog:/datalog \
-e "TZ=Asia/Shanghai" \
-e "ZOO_MY_ID=3" \
-e "ZOO_SERVERS=server.1=$machine_ip:2887:3887 server.2=$machine_ip:2888:3888 server.3=0.0.0.0:2888:3888" \
zookeeper:3.4.13

打开zookeeper连接工具ZooInspector进行测试,没毛病。。。。。。测试

相关文章
相关标签/搜索