一、安装环境:
1、系统:CentOS 7.0
2、Java环境:JDK8
zookeeper有单机、伪集群、集群三种部署方式
二、下载地址
官方链接:https://mirrors.tuna.tsinghua.edu.cn/apache/zookeeper/
会对应两个安装包如:apache-zookeeper-3.6.2.tar.gz和apache-zookeeper-3.6.2-bin.tar.gz
第一个直接运行会报错,需要安装maven,然后再运行mvn clean install 和 mvn javadoc:aggregate
第二个已经自带所需的各种jar包,不用再安装
结论:推荐使用第二个,带bin的安装包
百度网盘链接: https://pan.baidu.com/s/1YJ4dUh8By9Tt4SRpDA8jsg 提取码: m3ew
三、解压 tar -zxvf apache-zookeeper-3.6.2-bin.tar.gz
目录如下:
1、先将安装目录conf下,然后复制文件cp zoo_sample.cfg zoo.cfg(默认启动读取配置zoo.cfg)
2、关于配置文件说明
#The number of milliseconds of each tick
#tickTime:CS通信心跳数
#Zookeeper 服务器之间或客户端与服务器之间维持心跳的时间间隔,也就是每个 tickTime 时间就会发送一个心跳。tickTime以毫秒为单位。
tickTime=2000
#The number of ticks that the initial
#synchronization phase can take
#initLimit:LF初始通信时限
#集群中的follower服务器(F)与leader服务器(L)之间初始连接时能容忍的最多心跳数(tickTime的数量)。
initLimit=10
#The number of ticks that can pass between
#sending a request and getting an acknowledgement
#syncLimit:LF同步通信时限
#集群中的follower服务器与leader服务器之间请求和应答之间能容忍的最多心跳数(tickTime的数量)。
syncLimit=5
#the directory where the snapshot is stored.
#do not use /tmp for storage, /tmp here is just
#example sakes.
#dataDir:数据文件目录
#Zookeeper保存数据的目录,默认情况下,Zookeeper将写数据的日志文件也保存在这个目录里。
dataDir=/data/soft/zookeeper-3.4.12/data
#dataLogDir:日志文件目录
#Zookeeper保存日志文件的目录。
dataLogDir=/data/soft/zookeeper-3.4.12/logs
#the port at which the clients will connect
#clientPort:客户端连接端口
#客户端连接 Zookeeper 服务器的端口,Zookeeper 会监听这个端口,接受客户端的访问请求。
clientPort=2181
#the maximum number of client connections.
#increase this if you need to handle more clients
#maxClientCnxns=60
#Be sure to read the maintenance section of the
#administrator guide before turning on autopurge.
#http://zookeeper.apache.org/doc/current/zookeeperAdmin.html#sc_maintenance
#The number of snapshots to retain in dataDir 保留数量3
autopurge.snapRetainCount=3
#Purge task interval in hours
#Set to “0” to disable auto purge feature 清理时间间隔1小时
#autopurge.purgeInterval=1
#服务器名称与地址:集群信息(服务器编号,服务器地址,LF通信端口,选举端口)
#这个配置项的书写格式比较特殊,规则如下:
#server.N=YYY:A:B
#其中N表示服务器编号,YYY表示服务器的IP地址,A为LF通信端口,表示该服务器与集群中的leader交换的信息的端口。B为选举端口,表示选举新leader时服务器间相互通信的端口(当leader挂掉时,其余服务器会相互通信,选择出新的leader)。一般来说,集群中每个服务器的A端口都是一样,每个服务器的B端口也是一样。但是当所采用的为伪集群时,IP地址都一样,只能时A端口和B端口不一样。
四、相关命令
安装目录/bin下然后执行命令 ./zkServer.sh start
启动命令:./bin/zkServer.sh start
停止命令:./bin/zkServer.sh stop
重启命令:./bin/zkServer.sh restart
状态查看命令:./bin/zkServer.sh status
五、伪集群模式
伪集群模式就是在同一主机启动多个zookeeper并组成集群
可以通过复制三个zookeeper实例
配置文件如下:
如图实例一为:12181,依次实例二:12182, 实例三:12183
并且在对应的dataDir=/opt/zkPseudoCluster/zkdata12181目录下,新增文件myid,写入的值为对应server.1=127.0.0.1:12888:13888中server.后面的值1,2,3
如:
实例一zkdata12181下myid文件内容为1
实例二zkdata12182下myid文件内容为2
实例三zkdata12183下myid文件内容为3
六、集群模式
参考伪集群方式,在不同机器上安装zookeeper,然后把对应的127.0.0.1换成对应的ip地址即可