目錄
1、拉取映像
docker stop redis-node1 redis-node2 redis-node3
登入後複製
" >
docker stop redis-node1 redis-node2 redis-node3
登入後複製
首頁 資料庫 Redis 基於Docker的Redis集群如何搭建

基於Docker的Redis集群如何搭建

May 30, 2023 pm 12:46 PM
redis docker

環境:Docker ( Redis:5.0.5 * 3 )

1、拉取映像

docker  pull  redis:5.0.5
登入後複製

基於Docker的Redis集群如何搭建

##2、建立Redis容器

建立三個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集群如何搭建

執行完執行指令後檢查一下容器的啟動狀況:

基於Docker的Redis集群如何搭建

如果出現上圖情況,

Exited (1) 3 seconds ago,可以透過 docker logs 查看:

基於Docker的Redis集群如何搭建

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

chmod -R  777 /data
登入後複製

基於Docker的Redis集群如何搭建

組成集群

查看3個Redis在Docker中分配的ip結點資訊:

执行「docker inspect redis-node1」得到 redis-node1 ip 信息为:172.17.0.4 
执行「docker inspect redis-node2」得到 redis-node2 ip 信息为:172.17.0.3 
执行「docker inspect redis-node3」得到 redis-node3 ip 信息为:172.17.0.2
登入後複製
基於Docker的Redis集群如何搭建

拿到ip 資訊後(每個人的ip資訊可能不一樣),接下來進入某一個容器進行組成群集:

# 这里以进入 node1 为例
docker exec -it redis-node1 /bin/bash

# 接着执行组建集群命令(请根据自己的ip信息进行拼接)
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

 指令連接到叢集結點,然後set 值,set 值之後會自動重新導向到0.2 ip位址,然後透過get 取得一下,取得成功證明叢集有效。

基於Docker的Redis集群如何搭建

4、存在的問題

按照如上的步驟,雖然群集搭建成功了,但其實還是有點問題的,由於群集結點中的ip位址 是docket內部分配的,如:172.17.0.2 等,如果使用 redis叢集

 的專案跟叢集不在一台伺服器上,那麼專案是沒辦法使用叢集的,因為是存取不通的。

基於Docker的Redis集群如何搭建

一個解決方案是讓Docker使用 host模式 的網路連線類型,Docker在使用host模式下建立的容器是沒有自己獨立的網路命名空間的,是跟實體機共用一個網路空間,進而可以共用實體機的所有埠與IP

,這樣就可以讓公共網路直接存取容器了,儘管這種方式有安全隱患,但目前來說還沒找到其他可行性模式。

就存在的問題我們重新採用 host模式

,重新建立容器:
1、停止已執行的容器
docker stop redis-node1 redis-node2 redis-node3
登入後複製
2、刪除先前建立的容器
docker rm redis-node1 redis-node2 redis-node3

# 清空上面创建的配置文件
rm -rf /data/redis-data/node*
登入後複製
3、重新基於host模式建立

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
登入後複製
跟先前建立指令不同,一是指定了 --net 網路類型為  host,二是這種情況下就不需要連接埠對映了,例如 -p 6379:6379,因為此時需要對外共用容器連接埠服務,所以只需要指定對外暴露的連接埠 -p 6379-p 6380

 等。

基於Docker的Redis集群如何搭建

4、啟動容器並組成叢集

# 启动命令
docker start redis-node1 redis-node2 redis-node3

# 进入某一个容器
docker exec -it redis-node1 /bin/bash

# 组建集群,10.211.55.4为当前物理机的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

一個值,然後從其他節點再取得值來查看是否成功:

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集群如何搭建的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

<🎜>:泡泡膠模擬器無窮大 - 如何獲取和使用皇家鑰匙
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
北端:融合系統,解釋
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
Mandragora:巫婆樹的耳語 - 如何解鎖抓鉤
3 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

熱門話題

Java教學
1664
14
CakePHP 教程
1423
52
Laravel 教程
1321
25
PHP教程
1269
29
C# 教程
1249
24
docker怎麼退出容器 docker怎麼退出容器 Apr 15, 2025 pm 12:15 PM

退出 Docker 容器的四種方法:容器終端中使用 Ctrl D 快捷鍵容器終端中輸入 exit 命令宿主機終端中使用 docker stop &lt;container_name&gt; 命令宿主機終端中使用 docker kill &lt;container_name&gt; 命令(強制退出)

docker內的文件怎麼拷貝到外面 docker內的文件怎麼拷貝到外面 Apr 15, 2025 pm 12:12 PM

Docker 中將文件拷貝到外部主機的方法:使用 docker cp 命令:執行 docker cp [選項] &lt;容器路徑&gt; &lt;主機路徑&gt;。使用數據卷:在主機上創建目錄,在創建容器時使用 -v 參數掛載該目錄到容器內,實現文件雙向同步。

docker怎麼啟動容器 docker怎麼啟動容器 Apr 15, 2025 pm 12:27 PM

Docker 容器啟動步驟:拉取容器鏡像:運行 "docker pull [鏡像名稱]"。創建容器:使用 "docker create [選項] [鏡像名稱] [命令和參數]"。啟動容器:執行 "docker start [容器名稱或 ID]"。檢查容器狀態:通過 "docker ps" 驗證容器是否正在運行。

docker容器名稱怎麼查 docker容器名稱怎麼查 Apr 15, 2025 pm 12:21 PM

可以通過以下步驟查詢 Docker 容器名稱:列出所有容器(docker ps)。篩選容器列表(使用 grep 命令)。獲取容器名稱(位於 "NAMES" 列中)。

docker怎麼重啟 docker怎麼重啟 Apr 15, 2025 pm 12:06 PM

重啟 Docker 容器的方法:獲取容器 ID(docker ps);停止容器(docker stop &lt;container_id&gt;);啟動容器(docker start &lt;container_id&gt;);驗證重啟成功(docker ps)。其他方法:Docker Compose(docker-compose restart)或 Docker API(參考 Docker 文檔)。

docker怎麼啟動mysql docker怎麼啟動mysql Apr 15, 2025 pm 12:09 PM

在 Docker 中啟動 MySQL 的過程包含以下步驟:拉取 MySQL 鏡像創建並啟動容器,設置根用戶密碼並映射端口驗證連接創建數據庫和用戶授予對數據庫的所有權限

docker怎麼創建容器 docker怎麼創建容器 Apr 15, 2025 pm 12:18 PM

在 Docker 中創建容器: 1. 拉取鏡像: docker pull [鏡像名] 2. 創建容器: docker run [選項] [鏡像名] [命令] 3. 啟動容器: docker start [容器名]

docker怎麼查看日誌 docker怎麼查看日誌 Apr 15, 2025 pm 12:24 PM

查看 Docker 日誌的方法包括:使用 docker logs 命令,例如:docker logs CONTAINER_NAME使用 docker exec 命令運行 /bin/sh 並查看日誌文件,例如:docker exec -it CONTAINER_NAME /bin/sh ; cat /var/log/CONTAINER_NAME.log使用 Docker Compose 的 docker-compose logs 命令,例如:docker-compose -f docker-com

See all articles