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 https://mirrors.ustc.edu.cn/apache/zookeeper/zookeeper-3.6.2/apache-zookeeper-3.6.2-bin.tar.gz
[root@localhost ~]# tar -zxvf apache-zookeeper-3.6.2-bin.tar.gz -C /usr/local
3. 修改配置文件
3.1 zoo.cfg
[root@localhost ~]# cd /usr/local/apache-zookeeper-3.6.2-bin/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-bin
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