環境:Docker + ( Redis:5.0.5 * 3 )html
docker pull redis:5.0.5
建立三個 redis 容器:node
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 start
來啓動3個Redis容器:web
執行完運行命令後檢查一下容器的啓動狀況:redis
若是出現上圖狀況,Exited (1) 3 seconds ago
,能夠經過 docker logs
查看:docker
如上提示的是權限問題,咱們嘗試修改一下權限:安全
chmod -R 777 /data
啓動成功後以下圖所示:bash
查看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
拿到 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
ok,此時集羣搭建完了,咱們接下來測試一下。架構
使用 redis-cli -c
命令鏈接到集羣結點,而後 set 值,set 值以後會自動重定向到 0.2 ip地址,而後經過 get 獲取一下,獲取成功證實集羣有效。
按照如上的步驟,雖然集羣搭建成功了,但其實仍是有點問題的,因爲集羣結點中的 ip地址
是docket內部分配的,如:172.17.0.2
等,若是使用 redis集羣
的項目跟集羣不在一臺服務器上,那麼項目是無法使用集羣的,由於是訪問不通的。
一種解決方案是讓Docker使用 host模式
的網絡鏈接類型,Docker在使用host模式
下建立的容器是沒有本身獨立的網絡命名空間的,是跟物理機共享一個網絡空間,進而能夠共享物理機的全部端口與IP,這樣就可讓公共網絡直接訪問容器了,儘管這種方式有安全隱患,但目前來講還沒找到其餘可行性模式。
就存在的問題咱們從新採用 host模式
,從新建立一下容器:
docker stop redis-node1 redis-node2 redis-node3
docker rm redis-node1 redis-node2 redis-node3
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 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
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>
使用 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都是用的主節點,關於多副本、主從架構高可用在後文補充。
大家要的主從集羣:http://www.javashuo.com/article/p-rqrsoooc-nx.html
推薦閱讀: