Docker | redis集群部署實戰( 二 )

賦予start_redis_script.sh文件可執行權限[root@--- ~]# chmod o+x start_redis_script.sh執行腳本,啟動redis容器服務./start_redis_script.sh

Docker | redis集群部署實戰

文章插圖
查看redis容器[root@--- var]# docker psCONTAINER IDIMAGECOMMANDCREATEDSTATUSPORTSNAMES0d3c18b61098redis:5.0.9-alpine3.11"docker-entrypoint.s…"2 seconds agoUp 1 second0.0.0.0:6376->6379/tcp, 0.0.0.0:16376->16379/tcpredis-6ee896fb093daredis:5.0.9-alpine3.11"docker-entrypoint.s…"13 seconds agoUp 12 seconds0.0.0.0:6375->6379/tcp, 0.0.0.0:16375->16379/tcpredis-5a83bb7b16dffredis:5.0.9-alpine3.11"docker-entrypoint.s…"48 seconds agoUp 47 seconds0.0.0.0:6374->6379/tcp, 0.0.0.0:16374->16379/tcpredis-4ffe4c9619bedredis:5.0.9-alpine3.11"docker-entrypoint.s…"58 seconds agoUp 57 seconds0.0.0.0:6373->6379/tcp, 0.0.0.0:16373->16379/tcpredis-3a316a31e273fredis:5.0.9-alpine3.11"docker-entrypoint.s…"About a minute agoUp About a minute0.0.0.0:6372->6379/tcp, 0.0.0.0:16372->16379/tcpredis-271c072f57c29redis:5.0.9-alpine3.11"docker-entrypoint.s…"9 minutes agoUp 9 minutes0.0.0.0:6371->6379/tcp, 0.0.0.0:16371->16379/tcpredis-1[root@--- var]#創建集群進入任意一個 Redis 實例
進入redis-1容器docker exec -it redis-1 /bin/sh創建集群主節點
  • Redis Cluster最低要求是3個主節點
  • --cluster-replicas 參數為數字,1表示每個主節點需要1個從節點 。
# redis-1 容器內/data # redis-cli --cluster create 172.38.0.11:6379 172.38.0.12:6379 172.38.0.13:6379 172.38.0.14:6379 172.38.0.15:6379 172.38.0.16:6379 --cluster-replicas 1
Docker | redis集群部署實戰

文章插圖
測試連接集群連接集群 -c# redis-1 容器內/data # redis-cli -c127.0.0.1:6379>查看集群信息 cluster info127.0.0.1:6379> cluster infocluster_state:okcluster_slots_assigned:16384cluster_slots_ok:16384cluster_slots_pfail:0cluster_slots_fail:0cluster_known_nodes:6cluster_size:3cluster_current_epoch:6cluster_my_epoch:1cluster_stats_messages_ping_sent:292cluster_stats_messages_pong_sent:307cluster_stats_messages_sent:599cluster_stats_messages_ping_received:302cluster_stats_messages_pong_received:292cluster_stats_messages_meet_received:5cluster_stats_messages_received:599127.0.0.1:6379>查看節點信息 cluster nodes127.0.0.1:6379> cluster nodesb3f737d0d77b823794087011f1501fd43a2ea316 172.38.0.12:6379@16379 master - 0 1633332452560 2 connected 5461-10922506ff2bf1020d468e7d7a81ddbfb616a7e9b7d96 172.38.0.13:6379@16379 master - 0 1633332453000 3 connected 10923-163837f57f8a01493fa9e46e24ad8a9e46995634f7442 172.38.0.15:6379@16379 slave 70ebdca0264c079bb2c33452e6388d37706da282 0 1633332453000 5 connected70ebdca0264c079bb2c33452e6388d37706da282 172.38.0.11:6379@16379 myself,master - 0 1633332452000 1 connected 0-5460f839b6924977e99d3b74324f2ef70b3678e1a257 172.38.0.14:6379@16379 slave 506ff2bf1020d468e7d7a81ddbfb616a7e9b7d96 0 1633332453762 4 connectedbbc4dd0639b90e9ddfb5cef278be04a24276cbdb 172.38.0.16:6379@16379 slave b3f737d0d77b823794087011f1501fd43a2ea316 0 1633332453000 6 connected127.0.0.1:6379>
Docker | redis集群部署實戰

文章插圖
測試主從節點替換【Docker | redis集群部署實戰】驗證高可用
set一個值 , 然后停掉對應的服務,再次get,驗證是否可以得到值
set值127.0.0.1:6379> set a b-> Redirected to slot [15495] located at 172.38.0.13:6379OK172.38.0.13:6379>發現a值設置在了172.38.0.13容器上,然后我們試著去停掉redis-3容器的服務,然后再次get,看一下結果
get值172.38.0.13:6379> get a"b"172.38.0.13:6379>停止redis-3容器里的redis服務docker stop redis-3再次取值172.38.0.13:6379> get aCould not connect to Redis at 172.38.0.13:6379: Host is unreachable(34.04s)not connected> exit# 重連集群/data # redis-cli -c127.0.0.1:6379> get a-> Redirected to slot [15495] located at 172.38.0.14:6379"b"172.38.0.14:6379>發現a值被存儲到了172.38.0.14機器上,172.38.0.14172.38.0.13的從節點,當主節點172.38.0.13發生故障時,自動替換到172.38.0.13,這就是高可用
查看redis節點服務信息發現172.38.0.13節點fail, 172.38.0.14變成master
Docker | redis集群部署實戰

文章插圖
docker搭建redis集群完成
我是 甜點cc
熱愛前端,也喜歡專研各種跟本職工作關系不大的技術,技術、產品興趣廣泛且濃厚,等待著一個創業機會 。本號主要致力于分享個人經驗總結,希望可以給一小部分人一些微小幫助 。

推薦閱讀