Docker部署Zookeeper分布式協(xié)調(diào)器的實(shí)現(xiàn)
一、簡(jiǎn)介
Zookeeper 是一個(gè)開(kāi)源的分布式協(xié)調(diào)器,是一個(gè)典型的分布式數(shù)據(jù)一致性解決方案,其設(shè)計(jì)目的是將復(fù)雜且容易出錯(cuò)的分布式一致性服務(wù)封裝起來(lái),構(gòu)成一個(gè)高效可靠的系統(tǒng),并以一系列簡(jiǎn)單易用的原子操作提供給用戶(hù)使用。
二、部署
Zookeeper 支持單機(jī)和集群部署,集群部署時(shí),節(jié)點(diǎn)個(gè)數(shù)需要部署為奇數(shù)個(gè)。這里安裝的是 3.8.4 Tag版本,如果需要安裝其他或者最新版本,可以到 Docker Hub 進(jìn)行查找。
2.1 單節(jié)點(diǎn)部署
docker run -d ` -p 2181:2181 -p 2888:2888 -p 3888:3888 ` --restart always ` --name zookeeper-3.8.4 ` -v C:\ProgramDatas\Docker\Containers\zookeeper-3.8.4\data:/data ` -v C:\ProgramDatas\Docker\Containers\zookeeper-3.8.4\datalog:/datalog ` zookeeper:3.8.4
-zookeeper 常用的三個(gè)端口。2181 端口主要用于對(duì)客戶(hù)端提供服務(wù)、3888 端口主要用于選舉leader、2888 端口主要用于集群內(nèi)機(jī)器通訊,特別是在 Leader 監(jiān)聽(tīng)此端口。
-參數(shù) -v C:\ProgramDatas\Docker\Containers\zookeeper-3.8.4\data:/data 內(nèi)存中的數(shù)據(jù)庫(kù)快照。
-參數(shù) -v C:\ProgramDatas\Docker\Containers\zookeeper-3.8.4\datalog:/datalog 更新數(shù)據(jù)的事務(wù)日志。
2.2 集群部署
集群部署,這里以 zookeeper1-3.8.4、zookeeper2-3.8.4、zookeeper3-3.8.4 三臺(tái)為例。
docker network create zookeeper-net
docker run -d ` -p 2181:2181 -p 2888:2888 -p 3888:3888 ` --restart always ` --name zookeeper1-3.8.4 ` --network=zookeeper-net ` -e ZOO_MY_ID="1" ` -e ZOO_SERVERS="server.1=zookeeper1-3.8.4:2888:3888;2181 server.2=zookeeper2-3.8.4:2889:3889;2182 server.3=zookeeper3-3.8.4:2890:3890;2183" ` -v C:\ProgramDatas\Docker\Containers\zookeeper1-3.8.4\data:/data ` -v C:\ProgramDatas\Docker\Containers\zookeeper1-3.8.4\datalog:/datalog ` zookeeper:3.8.4
docker run -d -p 2182:2181 -p 2889:2888 -p 3889:3888 ` --restart always ` --name zookeeper2-3.8.4 ` --network=zookeeper-net ` -e ZOO_MY_ID="2" -e ZOO_SERVERS="server.1=zookeeper1-3.8.4:2888:3888;2181 server.2=zookeeper2-3.8.4:2889:3889;2182 server.3=zookeeper3-3.8.4:2890:3890;2183" ` -v C:\ProgramDatas\Docker\Containers\zookeeper2-3.8.4\data:/data ` -v C:\ProgramDatas\Docker\Containers\zookeeper2-3.8.4\datalog:/datalog ` zookeeper:3.8.4
docker run -d ` -p 2813:2181 -p 2890:2888 -p 3890:3888 ` --restart always ` --network=zookeeper-net ` -e ZOO_MY_ID="3" ` -e ZOO_SERVERS="server.1=zookeeper1-3.8.4:2888:3888;2181 server.2=zookeeper2-3.8.4:2889:3889;2182 server.3=zookeeper3-3.8.4:2890:3890;2183" ` -v C:\ProgramDatas\Docker\Containers\zookeeper3-3.8.4\data:/data ` -v C:\ProgramDatas\Docker\Containers\zookeeper3-3.8.4\datalog:/datalog ` --name zookeeper3-3.8.4 ` zookeeper:3.8.4
部署完成后,使用命令 ./bin/zkServer.sh status 分別進(jìn)去三個(gè) Zookeeper,查看每臺(tái)分別處于什么角色(leader、follower)。
可以看到 zookeeper3-3.8.4 是 leader,zookeeper1-3.8.4、zookeeper2-3.8.4 是 follower??梢詳U(kuò)展測(cè)一下,把 zookeeper3-3.8.4 關(guān)閉,然后再看一下 zookeeper1-3.8.4、zookeeper2-3.8.4 是否正常進(jìn)行了選舉。
三、連接 Zookeeper
使用 PrettyZoo 軟件(或者 ZooKeeper Assistant、zkdash、zkui、ZooInspector)連接 Zookeeper,地址使用 127.0.0.1 端口為 2181,默認(rèn)沒(méi)有用戶(hù)名與密碼??吹饺缦拢珼ocker 中的 Zookeeper 即代表部署成功。
四、配置映射
如果需要配置 zookeeper 的話,會(huì)用到 zoo.cfg 配置文件。容器版本的 Zookeeper 在執(zhí)行啟動(dòng)命令后,會(huì)將命令中的一些信息,寫(xiě)入到容器內(nèi) /conf/zoo.cfg 文件中(端口、ID 等信息)。所以,需要將容器內(nèi)的 /conf/zoo.cfg 文件拷貝到物理機(jī),并進(jìn)行映射。
為了方便,可以將整個(gè) /conf 文件夾拷貝到物理機(jī),并進(jìn)行映射。
4.1 單機(jī)
- 使用下面命令,把容器內(nèi)的 /conf 文件夾拷貝的物理機(jī),然后停止并刪除容器。
docker cp zookeeper-3.8.4:/conf C:\ProgramDatas\Docker\Containers\zookeeper-3.8.4\conf docker stop zookeeper-3.8.4 docker rm zookeeper-3.8.4
- 重新部署容器,在啟動(dòng)容器的命令中,加一條 -v 參數(shù)進(jìn)行路徑的映射。
-v C:\ProgramDatas\Docker\Containers\zookeeper-3.8.4\conf:/conf
4.2 集群
如果部署的是個(gè)集群,拷貝容器內(nèi)的 /conf 文件夾到物理機(jī),需要從每個(gè)節(jié)點(diǎn)對(duì)應(yīng)部署命令啟動(dòng)的容器中進(jìn)行拷貝,不可以使用同一個(gè)容器內(nèi)的 /conf 文件夾中的配置文件。
到此這篇關(guān)于Docker部署Zookeeper分布式協(xié)調(diào)器的實(shí)現(xiàn)的文章就介紹到這了,更多相關(guān)Docker部署Zookeeper 內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
maven構(gòu)建docker鏡像push到鏡像倉(cāng)庫(kù)方式
這篇文章主要介紹了maven構(gòu)建docker鏡像push到鏡像倉(cāng)庫(kù)方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-11-11Docker Compose引用環(huán)境變量的方法示例
在項(xiàng)目中,往往需要在 docker-compose.yml 文件中使用環(huán)境變量來(lái)控制不同的條件和使用場(chǎng)景。本文集中介紹 docker compose 引用環(huán)境變量的方式,感興趣的小伙伴們可以參考一下2018-12-12docker容器運(yùn)行后退出(怎么才能一直運(yùn)行)
這篇文章主要介紹了docker容器運(yùn)行后退出(怎么才能一直運(yùn)行),本文詳細(xì)的介紹了解決方法,非常具有實(shí)用價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-01-01六種Docker目錄掛載類(lèi)型及注意事項(xiàng)總結(jié)
這篇文章主要介紹了六種Docker目錄掛載方式,包括數(shù)據(jù)卷掛載、綁定掛載、臨時(shí)文件系統(tǒng)掛載、命名卷掛載、匿名卷掛載和卷驅(qū)動(dòng)掛載,并詳細(xì)說(shuō)明了每種掛載方式的定義、舉例和注意事項(xiàng),需要的朋友可以參考下2025-03-03Docker-Compose搭建Spark集群的實(shí)現(xiàn)方法
本文主要介紹了Docker-Compose搭建Spark集群的實(shí)現(xiàn)方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2022-05-05vscode利用ssh配置docker容器并開(kāi)啟遠(yuǎn)程編程模式的詳細(xì)步驟
這篇文章主要介紹了vscode利用ssh配置docker容器內(nèi)開(kāi)啟遠(yuǎn)程編程模式,本文給大家講解的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-03-03docker-compose編排單體nacos、rabbitmq、redis基礎(chǔ)服務(wù)詳解
這篇文章主要介紹了docker-compose編排單體nacos、rabbitmq、redis基礎(chǔ)服務(wù),具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2025-04-04