中文字幕日韩精品一区二区免费_精品一区二区三区国产精品无卡在_国精品无码专区一区二区三区_国产αv三级中文在线

Docker上實(shí)現(xiàn)Redis集群搭建

目錄

安鄉(xiāng)網(wǎng)站制作公司哪家好,找創(chuàng)新互聯(lián)!從網(wǎng)頁(yè)設(shè)計(jì)、網(wǎng)站建設(shè)、微信開發(fā)、APP開發(fā)、響應(yīng)式網(wǎng)站開發(fā)等網(wǎng)站項(xiàng)目制作,到程序開發(fā),運(yùn)營(yíng)維護(hù)。創(chuàng)新互聯(lián)公司2013年成立到現(xiàn)在10年的時(shí)間,我們擁有了豐富的建站經(jīng)驗(yàn)和運(yùn)維經(jīng)驗(yàn),來(lái)保證我們的工作的順利進(jìn)行。專注于網(wǎng)站建設(shè)就選創(chuàng)新互聯(lián)。

環(huán)境:Docker + ( Redis:5.0.5 * 3 )

1、拉取鏡像docker pull redis:5.0.52、創(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.confdocker 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.confdocker 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.conf3、啟動(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)目是沒法使用集群的,因?yàn)槭窃L問(wèn)不通的。一種解決方案是讓Docker使用 host模式 的網(wǎng)絡(luò)連接類型,Docker在使用host模式下創(chuàng)建的容器是沒有自己獨(dú)立的網(wǎng)絡(luò)命名空間的,是跟物理機(jī)共享一個(gè)網(wǎng)絡(luò)空間,進(jìn)而可以共享物理機(jī)的所有

端口與IP,這樣就可以讓公共網(wǎng)絡(luò)直接訪問(wèn)容器了,盡管這種方式有安全隱患,但目前來(lái)說(shuō)還沒找到其他可行性模式。

就存在的問(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 6379docker 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 6380docker 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ò)類型為 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-cli127.0.0.1:6379> cluster nodes72c291c32815194b64d1f6d0fdf771f5cc04e14a 10.211.55.4:6380@16380 master - 0 1590905997358 2 connected 5461-109226a595b67bbff15c94e5874c2d2cd556d6a6a6c17 10.211.55.4:6381@16381 master - 0 1590905998362 3 connected 10923-163834e3dbdc8f835dcbc38291c88f08165ee51d53d3d 10.211.55.4:6379@16379 myself,master - 0 1590905997000 1 connected 0-5460127.0.0.1:6379>

6、測(cè)試集群

使用 redis-cli -c 連接到集群上,set一個(gè)值,然后從其他節(jié)點(diǎn)再獲取值查看是否成功:

root@CentOS7:/data# redis-cli -c127.0.0.1:6379> set wxiaowei 123-> Redirected to slot [7515] located at 10.211.55.4:6380OK10.211.55.4:6380> get wxiaowei"123"

至此,本次基于Docker的Redis集群?jiǎn)胃北灸J剿闶谴罱ê昧?,文?個(gè)redis都是用的主節(jié)點(diǎn),關(guān)于多副本、主從架構(gòu)高可用在后文補(bǔ)充。

你們要的主從集群:

到此這篇關(guān)于Docker上實(shí)現(xiàn)Redis集群搭建 的文章就介紹到這了,更多相關(guān)Docker Redis集群搭建內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

網(wǎng)站欄目:Docker上實(shí)現(xiàn)Redis集群搭建
網(wǎng)址分享:http://www.rwnh.cn/article16/dhpgg.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供搜索引擎優(yōu)化域名注冊(cè)、面包屑導(dǎo)航、關(guān)鍵詞優(yōu)化網(wǎng)站營(yíng)銷、云服務(wù)器

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

網(wǎng)站托管運(yùn)營(yíng)
顺平县| 盐亭县| 青川县| 龙口市| 二手房| 湖南省| 清水县| 汉源县| 仁寿县| 嘉峪关市| 将乐县| 蚌埠市| 驻马店市| 襄汾县| 和田县| 肃北| 江口县| 阿瓦提县| 镇宁| 丰县| 洪洞县| 澜沧| 克东县| 通州市| 手游| 东乡族自治县| 河南省| 西昌市| 东光县| 灵川县| 土默特左旗| 禄丰县| 常宁市| 嫩江县| 鄢陵县| 友谊县| 页游| 抚顺县| 泸溪县| 乐山市| 什邡市|