Docker上實(shí)現(xiàn)Redis集群搭建
環(huán)境:Docker + ( Redis:5.0.5 * 3 )
1、拉取鏡像
docker pull redis:5.0.5
2、創(chuàng)建Redis容器
創(chuàng)建三個(gè) redis 容器:
redis-node1:6379
redis-node2:6380
redis-node3:6381
docker create --name redis-node1 -v /data/redis-data/node1:/data -p 6379:6379 redis:5.0.5 --cluster-enabled yes --cluster-config-file nodes-node-1.conf docker create --name redis-node2 -v /data/redis-data/node2:/data -p 6380:6379 redis:5.0.5 --cluster-enabled yes --cluster-config-file nodes-node-2.conf docker create --name redis-node3 -v /data/redis-data/node3:/data -p 6381:6379 redis:5.0.5 --cluster-enabled yes --cluster-config-file nodes-node-3.conf
3、啟動(dòng)并組建集群?jiǎn)?dòng)容器
首先通過(guò)命令docker start
來(lái)啟動(dòng)3個(gè)Redis容器:
執(zhí)行完運(yùn)行命令后檢查一下容器的啟動(dòng)情況:
如果出現(xiàn)上圖情況,Exited (1) 3 seconds ago
,可以通過(guò) docker logs
查看:
如上提示的是權(quán)限問(wèn)題,我們嘗試修改一下權(quán)限:
chmod -R 777 /data
啟動(dòng)成功后如下圖所示:
組建集群
查看3個(gè)Redis在Docker中分配的ip結(jié)點(diǎn)信息:
執(zhí)行「docker inspect redis-node1」得到 redis-node1 ip 信息為:172.17.0.4
執(zhí)行「docker inspect redis-node2」得到 redis-node2 ip 信息為:172.17.0.3
執(zhí)行「docker inspect redis-node3」得到 redis-node3 ip 信息為:172.17.0.2
拿到 ip 信息后(每個(gè)人的ip信息可能不一樣),接下來(lái)進(jìn)入某一個(gè)容器進(jìn)行組建集群:
# 這里以進(jìn)入 node1 為例 docker exec -it redis-node1 /bin/bash # 接著執(zhí)行組建集群命令(請(qǐng)根據(jù)自己的ip信息進(jìn)行拼接) redis-cli --cluster create 172.17.0.2:6379 172.17.0.3:6379 172.17.0.4:6379 --cluster-replicas 0
ok,此時(shí)集群搭建完了,我們接下來(lái)測(cè)試一下。
測(cè)試集群
使用 redis-cli -c
命令連接到集群結(jié)點(diǎn),然后 set 值,set 值之后會(huì)自動(dòng)重定向到 0.2 ip地址,然后通過(guò) get 獲取一下,獲取成功證明集群有效。
4、存在的問(wèn)題
按照如上的步驟,雖然集群搭建成功了,但其實(shí)還是有點(diǎn)問(wèn)題的,由于集群結(jié)點(diǎn)中的 ip地址
是docket內(nèi)部分配的,如:172.17.0.2
等,如果使用 redis集群
的項(xiàng)目跟集群不在一臺(tái)服務(wù)器上,那么項(xiàng)目是沒(méi)法使用集群的,因?yàn)槭窃L問(wèn)不通的。
一種解決方案是讓Docker使用 host模式
的網(wǎng)絡(luò)連接類(lèi)型,Docker在使用host模式
下創(chuàng)建的容器是沒(méi)有自己獨(dú)立的網(wǎng)絡(luò)命名空間的,是跟物理機(jī)共享一個(gè)網(wǎng)絡(luò)空間,進(jìn)而可以共享物理機(jī)的所有端口與IP,這樣就可以讓公共網(wǎng)絡(luò)直接訪問(wèn)容器了,盡管這種方式有安全隱患,但目前來(lái)說(shuō)還沒(méi)找到其他可行性模式。
就存在的問(wèn)題我們重新采用 host模式
,重新創(chuàng)建一下容器:
1、停止已運(yùn)行的容器
docker stop redis-node1 redis-node2 redis-node3
2、刪除之前創(chuàng)建的容器
docker rm redis-node1 redis-node2 redis-node3 # 清空上面創(chuàng)建的配置文件 rm -rf /data/redis-data/node*
3、重新基于host模式創(chuàng)建
docker create --name redis-node1 --net host -v /data/redis-data/node1:/data redis:5.0.5 --cluster-enabled yes --cluster-config-file nodes-node-1.conf --port 6379 docker create --name redis-node2 --net host -v /data/redis-data/node2:/data redis:5.0.5 --cluster-enabled yes --cluster-config-file nodes-node-2.conf --port 6380 docker create --name redis-node3 --net host -v /data/redis-data/node3:/data redis:5.0.5 --cluster-enabled yes --cluster-config-file nodes-node-3.conf --port 6381
跟之前創(chuàng)建命令不同,一是指定了 --net
網(wǎng)絡(luò)類(lèi)型為 host
,二是這種情況下就不需要端口映射了,比如 -p 6379:6379
,因?yàn)榇藭r(shí)需要對(duì)外共享容器端口服務(wù),所以只需要指定對(duì)外暴露的端口 -p 6379
、-p 6380
等。
4、啟動(dòng)容器并組建集群
# 啟動(dòng)命令 docker start redis-node1 redis-node2 redis-node3 # 進(jìn)入某一個(gè)容器 docker exec -it redis-node1 /bin/bash # 組建集群,10.211.55.4為當(dāng)前物理機(jī)的ip地址 redis-cli --cluster create 10.211.55.4:6379 10.211.55.4:6380 10.211.55.4:6381 --cluster-replicas 0
5、查看集群信息
root@CentOS7:/data# redis-cli 127.0.0.1:6379> cluster nodes 72c291c32815194b64d1f6d0fdf771f5cc04e14a 10.211.55.4:6380@16380 master - 0 1590905997358 2 connected 5461-10922 6a595b67bbff15c94e5874c2d2cd556d6a6a6c17 10.211.55.4:6381@16381 master - 0 1590905998362 3 connected 10923-16383 4e3dbdc8f835dcbc38291c88f08165ee51d53d3d 10.211.55.4:6379@16379 myself,master - 0 1590905997000 1 connected 0-5460 127.0.0.1:6379>
6、測(cè)試集群
使用 redis-cli -c
連接到集群上,set
一個(gè)值,然后從其他節(jié)點(diǎn)再獲取值查看是否成功:
root@CentOS7:/data# redis-cli -c 127.0.0.1:6379> set wxiaowei 123 -> Redirected to slot [7515] located at 10.211.55.4:6380 OK 10.211.55.4:6380> get wxiaowei "123"
至此,本次基于Docker的Redis集群單副本模式
算是搭建好了,文中3個(gè)redis都是用的主節(jié)點(diǎn),關(guān)于多副本、主從架構(gòu)高可用在后文補(bǔ)充。
你們要的主從集群:http://www.dbjr.com.cn/article/212285.htm
到此這篇關(guān)于Docker上實(shí)現(xiàn)Redis集群搭建 的文章就介紹到這了,更多相關(guān)Docker Redis集群搭建內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
docker建立私有倉(cāng)庫(kù)的過(guò)程
這篇文章主要介紹了docker私有倉(cāng)庫(kù)的建立,在這需要注意從私有倉(cāng)庫(kù)下載先移出原鏡像,具體操作過(guò)程跟隨小編一起看看吧2022-01-01淺談關(guān)于Docker容器互聯(lián)的初步實(shí)踐
這篇文章主要介紹了淺談關(guān)于Docker容器互聯(lián)的初步實(shí)踐,本文介紹了使用網(wǎng)橋(bridge)來(lái)對(duì)容器進(jìn)行互聯(lián),非常具有實(shí)用價(jià)值,需要的朋友可以參考下2018-10-10docker啟動(dòng)鏡像失敗后如何用日志logs查找失敗原因及解決
在使用docker的時(shí)候,在某些未知的情況下可能啟動(dòng)了容器,但是過(guò)了沒(méi)幾秒容器自動(dòng)退出了,這個(gè)時(shí)候如何排查問(wèn)題呢?下面這篇文章主要給大家介紹了關(guān)于docker啟動(dòng)鏡像失敗后如何用日志logs查找失敗原因及解決的相關(guān)資料,需要的朋友可以參考下2023-05-05docker 打包本地鏡像,并到其他機(jī)器進(jìn)行恢復(fù)操作
這篇文章主要介紹了docker 打包本地鏡像,并到其他機(jī)器進(jìn)行恢復(fù)操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-11-11idea鏈接不上虛擬機(jī)的docker里的mongodb問(wèn)題及解決
這篇文章主要介紹了idea鏈接不上虛擬機(jī)的docker里的mongodb問(wèn)題及解決,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-06-06docker+jenkins+gitee配置持續(xù)集成部署方式
這篇文章主要介紹了docker+jenkins+gitee配置持續(xù)集成部署方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-09-09docker網(wǎng)絡(luò),docker-compose?network問(wèn)題
這篇文章主要介紹了docker網(wǎng)絡(luò),docker-compose?network問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-01-01詳解Docker私有倉(cāng)庫(kù)最簡(jiǎn)便的搭建方法
本篇文章主要介紹了Docker私有倉(cāng)庫(kù)最簡(jiǎn)便的搭建方法,具有一定的參考價(jià)值,有興趣的可以了解一下。2017-02-02淺談Docker基礎(chǔ)之?dāng)?shù)據(jù)管理
這篇文章主要介紹了淺談Docker基礎(chǔ)之?dāng)?shù)據(jù)管理,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-03-03