1. 首先创建3台linux虚拟机
1.1 复制已有的centos虚拟机为3份(zookeeper集群最少3台)
1.2 将3台虚拟机配置静态IP(具体请参考:【linux-网络-静态IP配置】)
2. 下载zookeeper,并且上传到linux系统上。解压,我使用的版本是apache-zookeeper-3.6.2-bin
官方网址:https://zookeeper.apache.org/releases.html
3. 配置zookeeper
3.1 配置zoo.cfg
以我本地为例
cd /root/software/apache-zookeeper-3.6.2-bin/conf
mv zoo_sample.cfg zoo.cfg
vim zoo.cfg
将数据目录修改为指定的目录,注意这个目录要求不能重启后数据消失了。
3.2 配置解释如下
zookeeper的默认配置文件为zookeeper/conf/zoo_sample.cfg,需要将其修改为zoo.cfg。其中各配置项的含义,解释如下:
1.tickTime:CS通信心跳时间 Zookeeper 服务器之间或客户端与服务器之间维持心跳的时间间隔,也就是每个 tickTime 时间就会发送一个心跳。tickTime以毫秒为单位。 tickTime=2000
2.initLimit:LF初始通信时限 集群中的follower服务器(F)与leader服务器(L)之间初始连接时能容忍的最多心跳数(tickTime的数量)。
initLimit=53.syncLimit:LF同步通信时限 集群中的follower服务器与leader服务器之间请求和应答之间能容忍的最多心跳数(tickTime的数量)。 syncLimit=2
4.dataDir:数据文件目录 Zookeeper保存数据的目录,默认情况下,Zookeeper将写数据的日志文件也保存在这个目录里。 dataDir=/home/michael/opt/zookeeper/data
5.clientPort:客户端连接端口 客户端连接 Zookeeper 服务器的端口,Zookeeper 会监听这个端口,接受客户端的访问请求。 clientPort=2181
6.服务器名称与地址:集群信息(服务器编号,服务器地址,LF通信端口,选举端口) 这个配置项的书写格式比较特殊,规则如下: server.N=YYY:A:B
server.1=192.168.182.101:2888:3888
server.2=192.168.182.102:2888:3888
server.3=192.168.182.103:2888:3888
3.3 配置myid
在你上一步指定的dataDir所在目录新增文件myid,改为上面配置的数字server.1这个1,配置其他linux节点同样分别配置为2和3.
vim /data/zookeeper/data/myid
4. 按照3的配置配置其余2台zookeeper配置即可。
其他:在server.2=192.168.182.102:2888:3888这个配置中,可以将192.168.182.102替换为你本机的主机名,可以通过hostname查看。也可以修改你的主机名,然后把主机名替换192.168.182.102。
5. zookeeper一些基本命令
./zkServer.sh start 启动ZK
./zkServer.sh status 查看ZK状态
./zkCli.sh 打开ZK客户端
进入客户端后,即
./zkCli.sh 打卡ZK客户端
create /testNode1 123 创建/下的节点/testNode1
get /testNode1 获取/testNode1节点
set /testNode1 设置/testNode1节点值
delete /testNode1 删除节点
quit 退出ZK客户端
至此Zookeeper集群搭建完毕~