日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

使用Docker-Compose搭建Redis集群

發布時間:2024/1/18 数据库 38 豆豆
生活随笔 收集整理的這篇文章主要介紹了 使用Docker-Compose搭建Redis集群 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

1. 集群配置

  • 3主+3從

  • 由于僅用于測試,故我這里只用1臺服務器進行模擬

redis列表

2.編寫redis.conf

在server上創建一個目錄用于存放redis集群部署文件。這里我放的路徑為/root/redis-cluster

在/opt/docker/redis-cluster目錄下創建redis-1,redis-2,redis-3,redis-4,redis-5,redis-6文件夾

mkdir -p /opt/docker/redis-cluster/{redis-1,redis-2,redis-3,redis-4,redis-5,redis-6}#創建持久化目錄 mkdir -p /opt/docker/redis-cluster/redis-1/data mkdir -p /opt/docker/redis-cluster/redis-2/data mkdir -p /opt/docker/redis-cluster/redis-3/data mkdir -p /opt/docker/redis-cluster/redis-4/data mkdir -p /opt/docker/redis-cluster/redis-5/data mkdir -p /opt/docker/redis-cluster/redis-6/data

3. 在每個redis-*文件夾下創建redis.conf文件,并寫入如下內容:

cluster-enabled yes # 開啟集群 cluster-config-file nodes.conf # 集群配置文件 cluster-node-timeout 5000 # 集群節點多少時間未響應視為該節點丟失 appendonly yes port 6379 # redis監聽端口 masterauth passwd123 #設置master節點密碼 requirepass passwd123 #設置密碼

注意:port值不能都為6379,根據上面redis列表設置的端口號,依次給redis-1 ~ redis-6設置6379~6384端口號

4.編寫docker-compose.yml文件

這里直接使用daocloud提供的redis鏡像地址daocloud.io/library/redis:6.0.4

在/root/redis-cluster文件夾下創建docker-compose.yml文件。

docker-compose.yml文件內容如下:

version: '3.1' services:# redis1配置redis1:image: daocloud.io/library/redis:6.0.4container_name: redis-1restart: alwaysnetwork_mode: "host"volumes:- /opt/docker/redis-cluster/redis-1/data:/data- /opt/docker/redis-cluster/redis-1/redis.conf:/usr/local/etc/redis/redis.confcommand: ["redis-server", "/usr/local/etc/redis/redis.conf"]# redis2配置redis2:image: daocloud.io/library/redis:6.0.4container_name: redis-2restart: alwaysnetwork_mode: "host"volumes:- /opt/docker/redis-cluster/redis-2/data:/data- /opt/docker/redis-cluster/redis-2/redis.conf:/usr/local/etc/redis/redis.confcommand: ["redis-server", "/usr/local/etc/redis/redis.conf"]# redis3配置redis3:image: daocloud.io/library/redis:6.0.4container_name: redis-3restart: alwaysnetwork_mode: "host"volumes:- /opt/docker/redis-cluster/redis-3/data:/data- /opt/docker/redis-cluster/redis-3/redis.conf:/usr/local/etc/redis/redis.confcommand: ["redis-server", "/usr/local/etc/redis/redis.conf"]# redis4配置redis4:image: daocloud.io/library/redis:6.0.4container_name: redis-4restart: alwaysnetwork_mode: "host"volumes:- /opt/docker/redis-cluster/redis-4/data:/data- /opt/docker/redis-cluster/redis-4/redis.conf:/usr/local/etc/redis/redis.confcommand: ["redis-server", "/usr/local/etc/redis/redis.conf"]# redis5配置redis5:image: daocloud.io/library/redis:6.0.4container_name: redis-5restart: alwaysnetwork_mode: "host"volumes:- /opt/docker/redis-cluster/redis-5/data:/data- /opt/docker/redis-cluster/redis-5/redis.conf:/usr/local/etc/redis/redis.confcommand: ["redis-server", "/usr/local/etc/redis/redis.conf"]# redis6配置redis6:image: daocloud.io/library/redis:6.0.4container_name: redis-6restart: alwaysnetwork_mode: "host"volumes:- /opt/docker/redis-cluster/redis-6/data:/data- /opt/docker/redis-cluster/redis-6/redis.conf:/usr/local/etc/redis/redis.confcommand: ["redis-server", "/usr/local/etc/redis/redis.conf"]

啟動容器,執行命令:

#啟動容器 docker-compose -f xxx.yaml up -d

5.開啟集群

隨便找一個容器進入,這里我選擇redis-1進入。 在進入容器后,輸入如下命令開啟集群:

redis-cli --cluster create 192.168.66.180:6379 \ 192.168.66.180:6380 \ 192.168.66.180:6381 \ 192.168.66.180:6382 \ 192.168.66.180:6383 \ 192.168.66.180:6384 \ --cluster-replicas 1

出現下圖即為成功。

6.測試

使用redis-cli命令,連接集群中任意節點。(隨便找一臺能ping通集群所在IP的電腦,這里我用的本機進行測試)

6.1 查看節點屬性

redis-cli -c -h 192.168.66.180 -p 6379192.168.66.180:6379> cluster info

顯示為如下圖,即為集群健康狀態

6.2 查看節點信息

cluster nodes

注意看圖中的slave,master,myself等關鍵字。

6.3 插入一個值

192.168.66.180:6379> set test 'hello world' -> Redirected to slot [6918] located at 192.168.66.180:6380 OK 192.168.66.180:6380>

注意:這里根據切片自動切換到了該數據分片所在的節點上,所以下面可以看到連接的節點變為了192.168.1.4:6380

get test

168.66.180:6379> set test 'hello world' -> Redirected to slot [6918] located at 192.168.66.180:6380 OK 192.168.66.180:6380> get test "hello world" 192.168.66.180:6380>

這里因為就是在該數據所在分片上進行的查詢,所以連接節點沒有改變。

7.添加密碼

7.1 編輯redis.conf文件

#為redis.conf文件添加如下配置。這里設置密碼為123456 masterauth 123456 requirepass 123456

7.2 編輯docker-compose.yml文件

#為docker-compose.yml中每個容器添加如下配置: environment:- REDISCLI_AUTH=123456

7.3 連接集群

redis-cli -c -h 192.168.66.180 -p 6379 -a 123456

總結

以上是生活随笔為你收集整理的使用Docker-Compose搭建Redis集群的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。