1. Environment
- Operation System: CentOS7.4
- Server IP: 172.50.1.211 & 172.50.1.212 & 172.50.1.218
- JDK: java version "1.8.0_241"
2. 下载并解压
zookeeper 官方下载地址
zookeeper 中国科学技术大学下载地址
[root@localhost ~]# wget http://mirror.bit.edu.cn/apache/zookeeper/zookeeper-3.6.2/apache-zookeeper-3.6.2.tar.gz
[root@localhost ~]# tar -zxvf apache-zookeeper-3.6.2.tar.gz -C /usr/local
3. 修改配置文件
3.1 zoo.cfg
[root@localhost ~]# cd /usr/local/zookeeper-3.6.2/conf && cp -ra zoo_sample.cfg zoo.cfg && cat zoo.cfg
# tickTime:基本事件单元,这个时间是作为Zookeeper服务器之间或客户端与服务器之间维持心跳的时间间隔,每隔tickTime时间就会发送一个心跳;最小 的session过期时间为2倍tickTime
tickTime=2000
# initLimit:允许follower连接并同步到Leader的初始化连接时间,以tickTime为单位。当初始化连接时间超过该值,则表示连接失败。
initLimit=10
# syncLimit:表示Leader与Follower之间发送消息时,请求和应答时间长度。如果follower在设置时间内不能与leader通信,那么此follower将会被丢弃。
syncLimit=5
# dataDir:存储内存中数据库快照的位置,除非另有说明,否则指向数据库更新的事务日志 (目录没有,需要手动创建)
dataDir=/data/zookeeper
# 监听端口
clientPort=2181
# server.A=B:C:D
# A:是服务器编号;B是服务器ip;C是Leader选举的端口;D是zk服务器之间的通信端口
server.0=172.50.1.211:2888:3888
server.1=172.50.1.212:2888:3888
server.2=172.50.1.218:2888:3888
3.2 create myid
# 在"172.50.1.211"上执行
[root@localhost ~]# echo 0 > /data/zookeeper/myid
# 在"172.50.1.212"上执行
[root@localhost ~]# echo 1 > /data/zookeeper/myid
# 在"172.50.1.218"上执行
[root@localhost ~]# echo 2 > /data/zookeeper/myid
4.配置zookeeper环境变量
# 三台机器都要执行
[root@localhost ~]# cat > /etc/profile.d/zk_env.sh << EOF
export ZK_HOME=/usr/local/apache-zookeeper-3.6.2
export PATH=$PATH:$ZK_HOME/bin
EOF
# 刷新环境变量生效
[root@localhost ~]# source /etc/profile
5.启动zookeeper服务
# 启动
[root@localhost ~]# zkServer.sh start
# 停止
[root@localhost ~]# zkServer.sh stop
# 重启
[root@localhost ~]# zkServer.sh restart
# 查看集群状态
[root@localhost ~]# zkServer.sh status