這裡我用到的是zookeeper-3.4.10
2.解壓到指定目錄
2.1集群節點
192.168.20.38
192.168.20.52
192.168.20.111
2.2解壓縮(三颱機器都執行)
將zookeeper-3.4.10.tar.gz上傳至home目錄
cd /home/
tar -zxvf zookeeper-3.4.10.tar.gz
修改資料夾名稱
mv zookeeper-3.4.10 zookeeper
修改配置檔名
mv /home/zookeeper/conf/zoo_sample.cfg /home/zookeeper/conf/zoo.cfg
建立資源目錄
mkdir -p /home/tmp/zookeeper/
2.3修改zoo.cfg配置檔案(三颱機器都修改)
vi /home/zookeeper/conf/zoo.cfg
ticktime=2000
initlimit=10
synclimit=5
datadir=/home/tmp/zookeeper/data
datalogdir=/home/tmp/zookeeper/log
clientport=2181
#clusters
server.1=192.168.20.38:12888:13888
server.2=192.168.20.52:12888:13888
server.3=192.168.20.111:12888:13888
2.4分別在data檔案新增myid檔案
192.168.20.38
cd /home/tmp/zookeeper/data
echo "1" > myid
192.168.20.52
cd /home/tmp/zookeeper/data
echo "2" > myid
192.168.20.111
cd /home/tmp/zookeeper/data
echo "3" > myid
可以分別開啟myid檔案檢視內容:
cat myid
2.5啟動zookeeper
cd /home/zookeeper/bin
啟動zookeeper命令:
./zkserver.sh start
檢視集群的狀態:
./zkserver.sh status
2.6驗證zookeeper的高可靠性:
關掉其中一台機器上的zookeeper,檢視其他兩台機器上zookeeper的status。
在zookeeper的選舉過程中,為了保證選舉過程最後能選出leader,就一定不能出現兩台機器得票相同的僵局,
所以一般的,要求zk集群的server數量一定要是奇數,也就是2n+1臺,並且,如果集群出現問題,
其中存活的機器必須大於n+1臺,否則leader無法獲得多數server的支援,系統就自動掛掉。
所以一般是3個或者3個以上節點。
3.zoo.cfg配置檔案引數說明
ticktime:這個時間是作為zookeeper 伺服器之間或客戶端與伺服器之間維持心跳的時間間隔,也就是每個 ticktime 時間就會傳送乙個心跳。
datadir:顧名思義就是 zookeeper儲存資料的目錄,預設情況下,zookeeper 將寫資料的日誌檔案也儲存在這個目錄裡。
datalogdir:顧名思義就是zookeeper 儲存日誌檔案的目錄。
clientport:這個埠就是客戶端連線zookeeper 伺服器的埠,zookeeper 會監聽這個埠,接受客戶端的訪問請求。
12888埠:代表訪問zookeeper的埠
13888埠:代表重新選舉leader的埠
4.參考資料
linux下的zookeeper啟動
埠 2181 在準備好相應的配置之後,可以直接通過zkserver.sh 這個指令碼進行服務的相關操作 zookeeper命令列工具類似於linux的shell環境,不過功能肯定不及shell啦,但是使用它我們可以簡單的對zookeeper進行訪問,資料建立,資料修改等操作.使用 zkcli.sh ...
Linux環境下安裝Zookeeper
下面來介紹一下怎麼在linux下面安裝zookeeper。本文的linux環境為centos6.5.在安裝zookeeper之前我們需要先做兩件事。第一是安裝oracle的jdk。具體的安裝步驟請看這裡 tar zxvf 來解壓zookeeper的安裝包。解壓完成之後我們進入到剛才解壓出來的資料夾下...
Linux環境下安裝Zookeeper
首先我們需要使用xftp把安裝包上傳到伺服器的 usr local目錄下,用tar zxvf來解壓zookeeper的安裝包。解壓完成之後我們進入到剛才解壓出來的資料夾下面,內容如下所示 解壓命令tar zxvf zookeeper 3.4.6.tar.gz 圖一我們進入到conf資料夾下面,將zo...