基於Docker的Redis集羣簡單搭建

環境:Docker + ( Redis:5.0.5 * 3 )

1、拉取鏡像

docker pull redis:5.0.5

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:6380 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、啓動並組建集羣

啓動容器

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

執行完運行命令後檢查一下容器的啓動情況:

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

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

chmod -R 777 /data

啓動成功後如下圖所示:

組建集羣

查看3個Redis在Docker中分配的ip結點信息:

docker inspect redis-node1 -> 172.17.0.4 
docker inspect redis-node2 -> 172.17.0.3 
docker inspect redis-node3 -> 172.17.0.2

接下來進入某一個容器進行組建集羣:

# 這裏以進入 node1 爲例
docker exec -it redis-node1 /bin/bash

# 接着執行組建集羣命令
redis-cli --cluster create 172.17.0.2:6379 172.17.0.3:6379 172.17.0.4:6379 -- cluster-replicas 0

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

測試集羣

使用 redis-cli -c 命令連接到集羣結點,然後 set 值,set 值之後會自動重定向到 0.2 ip地址,然後通過 get 獲取一下,獲取成功證明集羣有效。

4、存在的問題

按照如上的步驟,雖然集羣搭建成功了,但其實還是有點問題的,由於集羣結點中的 ip地址 是docket內部分配的,如:172.17.0.2 等,如果使用 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
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 等。

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

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集羣單副本模式算是搭建好了,文中3個redis都是用的主節點,關於多副本、主從架構高可用在後文補充。

推薦閱讀:

Docker安裝Redis

SpringBoot如何切換Redis默認庫

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章