1、环境准备
表1-1 集群节点配置信息
ip | 操作系统 | 内存 | 磁盘空间 | 安装软件 |
---|---|---|---|---|
10.166.50.231 | 64位Centos7标准版 | 8G | 127G | jdk1.8、zookeeper3.4.10、centos7 |
10.166.50.232 | 64位Centos7标准版 | 8G | 127G | jdk1.8、zookeeper3.4.10、centos7 |
10.166.50.233 | 64位Centos7标准版 | 8G | 127G | jdk1.8、zookeeper3.4.10、centos7 |
2、配置hosts文件
3、创建对应的目录和文件
mkdir /opt/software/zookeeper/data
mkdir /opt/software/zookeeper/dataLog
在/opt/software/zookeeper/data文件夹下面创建myid文件,myid文件内容编辑为1,其余两个机器分别配置上2和3。
vim /opt/software/zookeeper/data/myid
3.1、修改配置文件
解压zookeeper.3.4.10.tar.gz,并重命名。
tar -xvf zookeeper.3.4.10.tar.gz
mv zookeeper.3.4.10.tar.gz zookeeper
进入/opt/software/zookeeper/conf,将文件夹下的zoo_sample.cfg更名为zoo.cfg,或者新建一个zoo.cfg,然后将zoo_sample.cfg内容复制到zoo.cfg。这里采用新建一个zoo.cfg文件,并将zoo_sample.cfg文件内容追加到zoo.cfg文件尾。
vim /opt/software/zookeeper/conf/zoo.cfg
按ESC后按:,输入wq后按Enter即可。
cat zoo_sample.cfg >> zoo.cfg
在Linux中>>表示追加,>表示覆盖。
对zoo.cfg文件内容配置如下所示。
tickTime=2000
initLimit=10
syncLimit=5
dataDir=/opt/software/zookeeper/data
dataLogDir=/opt/software/zookeeper/dataLog
clientPort=2181
server.1=cluster1:2888:3888
server.2=cluster2:2888:3888
server.3=cluster3:2888:3888
tickTime:表示Zookeeper 服务器之间或客户端与服务器之间维持心跳的时间间隔,也就是每个 tickTime 时间就会发送一个心跳。tickTime以毫秒为单位。
initLimit:集群中的follower服务器(F)与leader服务器(L)之间初始连接时能容忍的最多心跳数(tickTime的数量)。
syncLimit:集群中的follower服务器与leader服务器之间请求和应答之间能容忍的最多心跳数(tickTime的数量)。
dataDir:Zookeeper保存数据的目录,默认情况下,Zookeeper将写数据的日志文件也保存在这个目录里。
dataLogDir:Zookeeper保存日志文件的目录。
clientPort:客户端连接 Zookeeper 服务器的端口,Zookeeper 会监听这个端口,接受客户端的访问请求。
server.1:服务器名称与地址:集群信息(服务器编号,服务器地址,LF通信端口,选举端口)
将配置好的zookeeper文件分发到10.166.50.232机器和10.166.50.233机器上。
4、启动和测试zookeeper集群
分别在集群各个节点启动命令
sh /opt/software/zookeeper/bin/zkServer.sh start
分别查看下集群各个节点的状态
sh /opt/software/zookeeper/bin/zkServer.sh status
5、问题记录
可能原因:
1、 端口被占用
修改conf/zoo.cfg文件,添加admin.serverPort=没被占用的端口号。
2、 ip地址不是本机网卡
quorumListenOnAllIPs=true