前言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进行测试,没毛病。。。。。。测试