centos7 docker 安裝 zookeeper 3.4.13 集群


 

假設三台主機的ip分別為:

  • 主機一:192.168.0.168
  • 主機二:192.168.0.169
  • 主機三:192.168.0.170

三台主機的安裝步驟相似,以主機一為例:

 

1. 查找zookeeper鏡像:

docker search zookeeper

 

4. 下載官方zookeeper鏡像:

docker pull docker.io/zookeeper:3.4.13

 

5. 下載完后可檢查鏡像:

docker images

 

6. 在三台主機上建立掛載目錄和zookeeper配置文件:

mkdir -p /usr/local/zookeeper/conf
mkdir -p /usr/local/zookeeper/data cd /usr/local/zookeeper/conf touch zoo.cfg vi zoo.cfg

三台主機上的zoo.cfg配置信息如下:

復制代碼
clientPort=2181
dataDir=/data
dataLogDir=/data/log
tickTime=2000
initLimit=5
syncLimit=2
autopurge.snapRetainCount=3
autopurge.purgeInterval=0
maxClientCnxns=60
server.0=192.168.0.168:2888:3888
server.1=192.168.0.169:2888:3888
server.2=192.168.0.170:2888:3888
復制代碼

在主機一168上為自己分配server id,命令如下:

cd /usr/local/zookeeper/data
touch myid
echo 0 > myid

在主機二169上為自己分配server id,命令如下:

cd /usr/local/zookeeper/data
touch myid
echo 1 > myid

在主機三170上為自己分配server id,命令如下:

cd /usr/local/zookeeper/data
touch myid
echo 2 > myid

 

7. 三台主機依次啟動容器:

docker run --privileged=true --network host -v /usr/local/zookeeper/data:/data -v /usr/local/zookeeper/conf:/conf --name zookeeper2181 -d docker.io/zookeeper:3.4.13

命令說明:

  • --network host: 使用主機上的網絡配置,如果不用這種模式,而用默認的bridge模式,會導致容器跨主機間通信失敗
  • -v /usr/local/zookeeper/data:/data:主機的數據目錄掛載到容器/data下
  • -v /usr/local/zookeeper/conf:/conf: 主機的配置目錄掛載到容器的/conf下,容器內的zkServer.sh默認會讀取/conf/zoo.cfg下的配置

都啟動完成后,每台主機的2181/2888/3888端口都會開放出來了

 

8. 檢查容器的啟動情況:

docker exec -it zookeeper2181 /bin/bash

進入容器內部后,其工作目錄為:/zookeeper-3.4.13(版本依據鏡像而定),執行zookeeper檢查:

復制代碼

[root@hserver2 data]# docker exec -it zookeeper2181 /bin/bash
bash-4.4# pwd
/zookeeper-3.4.13
bash-4.4# zkServer.sh status
ZooKeeper JMX enabled by default
Using config: /conf/zoo.cfg
Mode: leader
bash-4.4#

復制代碼

可以看到這個容器目前為leader狀態,至此集群已啟動完成。

 

9. 若啟動失敗了,通過如下命令觀察zookeeper的啟動日志:

docker logs zookeeper2181

內容示例如下:

[root@hserver2 data]# docker logs zookeeper2181
ZooKeeper JMX enabled by default
Using config: /conf/zoo.cfg
log4j:WARN No appenders could be found for logger (org.apache.zookeeper.server.quorum.QuorumPeerConfig).
log4j:WARN Please initialize the log4j system properly.
log4j:WARN See http://logging.apache.org/log4j/1.2/faq.html#noconfig for more info.

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM