成人午夜视频全免费观看高清-秋霞福利视频一区二区三区-国产精品久久久久电影小说-亚洲不卡区三一区三区一区

基于Docker的Redis集群如何搭建

今天小編給大家分享一下基于Docker的redis集群如何搭建的相關(guān)知識點(diǎn),內(nèi)容詳細(xì),邏輯清晰,相信大部分人都還太了解這方面的知識,所以分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后有所收獲,下面我們一起來了解一下吧。

創(chuàng)新互聯(lián)建站堅(jiān)持“要么做到,要么別承諾”的工作理念,服務(wù)領(lǐng)域包括:網(wǎng)站設(shè)計(jì)制作、成都網(wǎng)站建設(shè)、企業(yè)官網(wǎng)、英文網(wǎng)站、手機(jī)端網(wǎng)站、網(wǎng)站推廣等服務(wù),滿足客戶于互聯(lián)網(wǎng)時代的蓮花網(wǎng)站設(shè)計(jì)、移動媒體設(shè)計(jì)的需求,幫助企業(yè)找到有效的互聯(lián)網(wǎng)解決方案。努力成為您成熟可靠的網(wǎng)絡(luò)建設(shè)合作伙伴!

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

1、拉取鏡像

docker  pull  redis:5.0.5

基于Docker的Redis集群如何搭建

2、創(chuàng)建Redis容器

創(chuàng)建三個 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

基于Docker的Redis集群如何搭建

3、啟動并組建集群

啟動容器

首先通過命令docker start來啟動3個Redis容器:

基于Docker的Redis集群如何搭建

執(zhí)行完運(yùn)行命令后檢查一下容器的啟動情況:

基于Docker的Redis集群如何搭建

如果出現(xiàn)上圖情況,Exited (1) 3 seconds ago,可以通過 docker logs 查看:

基于Docker的Redis集群如何搭建

如上提示的是權(quán)限問題,我們嘗試修改一下權(quán)限:

chmod -R  777 /data

啟動成功后如下圖所示:

基于Docker的Redis集群如何搭建

組建集群

查看3個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

基于Docker的Redis集群如何搭建

拿到 ip 信息后(每個人的ip信息可能不一樣),接下來進(jìn)入某一個容器進(jìn)行組建集群:

# 這里以進(jìn)入 node1 為例
docker exec -it redis-node1 /bin/bash

# 接著執(zhí)行組建集群命令(請根據(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

基于Docker的Redis集群如何搭建

ok,此時集群搭建完了,我們接下來測試一下。

測試集群

使用 redis-cli -c 命令連接到集群結(jié)點(diǎn),然后 set 值,set 值之后會自動重定向到 0.2 ip地址,然后通過 get 獲取一下,獲取成功證明集群有效。

基于Docker的Redis集群如何搭建

4、存在的問題

按照如上的步驟,雖然集群搭建成功了,但其實(shí)還是有點(diǎn)問題的,由于集群結(jié)點(diǎn)中的 ip地址 是docket內(nèi)部分配的,如:172.17.0.2 等,如果使用 redis集群 的項(xiàng)目跟集群不在一臺服務(wù)器上,那么項(xiàng)目是沒法使用集群的,因?yàn)槭窃L問不通的。

基于Docker的Redis集群如何搭建

一種解決方案是讓Docker使用 host模式 的網(wǎng)絡(luò)連接類型,Docker在使用host模式下創(chuàng)建的容器是沒有自己獨(dú)立的網(wǎng)絡(luò)命名空間的,是跟物理機(jī)共享一個網(wǎng)絡(luò)空間,進(jìn)而可以共享物理機(jī)的所有端口與IP,這樣就可以讓公共網(wǎng)絡(luò)直接訪問容器了,盡管這種方式有安全隱患,但目前來說還沒找到其他可行性模式。

就存在的問題我們重新采用 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ò)類型為 host,二是這種情況下就不需要端口映射了,比如 -p 6379:6379,因?yàn)榇藭r需要對外共享容器端口服務(wù),所以只需要指定對外暴露的端口 -p 6379、-p 6380 等。

基于Docker的Redis集群如何搭建

4、啟動容器并組建集群
# 啟動命令
docker start redis-node1 redis-node2 redis-node3

# 進(jìn)入某一個容器
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

基于Docker的Redis集群如何搭建

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、測試集群

使用 redis-cli -c 連接到集群上,set一個值,然后從其他節(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集群如何搭建

以上就是“基于Docker的Redis集群如何搭建”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家閱讀完這篇文章都有很大的收獲,小編每天都會為大家更新不同的知識,如果還想學(xué)習(xí)更多的知識,請關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。

網(wǎng)頁標(biāo)題:基于Docker的Redis集群如何搭建
鏈接地址:http://jinyejixie.com/article44/iepphe.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供動態(tài)網(wǎng)站、網(wǎng)站維護(hù)、Google、網(wǎng)站制作、電子商務(wù)、用戶體驗(yàn)

廣告

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

營銷型網(wǎng)站建設(shè)
万安县| 元氏县| 沾益县| 汕尾市| 潮安县| 区。| 慈利县| 宜君县| 屏山县| 远安县| 许昌县| 永济市| 北辰区| 张家川| 叙永县| 静安区| 布拖县| 通化市| 阳春市| 凤山市| 东辽县| 简阳市| 米泉市| 容城县| 抚顺县| 新密市| 宁远县| 墨玉县| 吴桥县| 城步| 读书| 香河县| 肃南| 沐川县| 永福县| 甘洛县| 西乡县| 牟定县| 巨野县| 左权县| 叙永县|