docker 搭建redis 集群

本文详细指导如何在Linux服务器上搭建3master、3slave的Redis Cluster,包括配置文件编写、镜像拉取、容器创建、集群初始化等关键步骤,并提醒注意事项。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

注意事项:


1. 不要建立在用户目录中。如root目录
2. 建议要给redis文件chomd -R 777 权限。
3. 在cluster-announce-ip 要输入docker ip,前两位以后缀开始。xxx.xxx.0.1 类似
4. 最后一步建立--cluster create 配置的是通讯本机ip的地址
5. 使用cluster nodes来查看配置信息
6. 【慎用:会删除所有docker容器。】配置错误的话记得使用docker rm -f $(docker ps -a -q) 删除所有容器。

建立3master、3从节点的基础redis-cluster集群

1、首先安装docker,安装完后建议切换镜像服务器,不然容易匿名拉取镜像过多导致无法拉取镜像。

在linux服务器上创建deamon.json文件--用于配置docker服务

vim /etc/docker/daemon.json
 
---写入内容 服务地址可网上找
{
    "registry-mirrors":["https://docker.mirrors.ustc.edu.cn"]
}
 
 
---然后重启docker centOS7下
systemctl daemon-reload
systemctl restart docker
2、拉取redis镜像 docker pull redis

3、在目标linux服务器中生成redis配置文件redis.conf

#port(端口号)
port ${PORT}
#masterauth(设置集群节点间访问密码,跟下面一致)
masterauth 123456
#requirepass(设置redis访问密码)
requirepass 123456
#cluster-enabled yes(启动集群模式)
cluster-enabled yes
#cluster-config-file nodes.conf(集群节点信息文件)
cluster-config-file nodes.conf
#cluster-node-timeout 5000(redis节点宕机被发现的时间)
cluster-node-timeout 5000
#cluster-announce-ip(集群节点的汇报ip,防止nat,预先填写为网关ip后续需要手动修改配置文件)
cluster-announce-ip 172.19.0.1
#cluster-announce-port(集群节点的汇报port,防止nat)
cluster-announce-port ${PORT}
#cluster-announce-bus-port(集群节点的汇报bus-port,防止nat)
cluster-announce-bus-port 1${PORT}
#appendonly yes(开启aof)    
appendonly yes
也可以批量在一台服务器上生成,创建shell脚本,输入下面内容,该脚本将批量生成6个redis配置文件对应端口6500-6505,redis-cluster.tmpl是上面的配置内容

for port in $(seq 6500 6505);
 do
    mkdir -p ./${port}/conf && PORT=${port} envsubst < ./redis-cluster.tmpl > ./${port}/conf/redis.conf && mkdir -p ./${port}/data;
done
4、创建容器,根据需要执行

docker run -d --net=host -v /usr/local/redis-cluster-d/6505/conf/redis.conf:/etc/redis/redis.conf -v /usr/local/redis-cluster-d/6505/data:/data --restart always  --privileged=true --name=redis-6505  redis redis-server /etc/redis/redis.conf
该命令中我批量生成的配置文件在/usr/local/redis-cluster-d/目录下,根据不同端口分为不同目录

5、查看创建好的容器 docker ps -a | grep redis

6、进入其中一台要设定master的节点docker容器中,2cd952c5a343为该容器ID

docker exec -it 2cd952c5a343 bash
7、执行集群初始化命令

redis-cli -a 123456 --cluster create 10.167.67.49:6500 10.167.67.49:6501 10.167.67.49:6502 10.167.67.49:6503 10.167.67.49:6504 10.167.67.49:6505 --cluster-replicas 1
初始化过程中会将各节点分配至不同的容器中,然后输入yes

8、完成后使用redis-cli 进行测试,执行命令,重点参数为-c 以集群的方式连接,不然将连接该单机节点,无法进行集群

redis-cli -c -a 123456  -h 10.167.67.49 -p 6500
 

要使用 Docker 搭建 Redis 集群,你可以按照以下步骤进行操作: 1. 确保已经安装并配置好了 Docker。 2. 创建一个用于 Redis 集群的自定义网络: ```bash docker network create redis-net ``` 3. 创建 Redis 主节点的容器。假设我们需要创建3个主节点,分别使用端口 7001、7002 和 7003: ```bash docker run -d --name redis1 --network redis-net -p 7001:6379 redis redis-server --port 6379 --cluster-enabled yes --cluster-config-file nodes.conf --cluster-node-timeout 5000 --appendonly yes docker run -d --name redis2 --network redis-net -p 7002:6379 redis redis-server --port 6379 --cluster-enabled yes --cluster-config-file nodes.conf --cluster-node-timeout 5000 --appendonly yes docker run -d --name redis3 --network redis-net -p 7003:6379 redis redis-server --port 6379 --cluster-enabled yes --cluster-config-file nodes.conf --cluster-node-timeout 5000 --appendonly yes ``` 这将创建三个 Redis 主节点容器,并将端口映射到主机的 7001、7002 和 7003 端口。 4. 创建 Redis 集群: ```bash docker run -it --rm --network redis-net redis redis-cli --cluster create <node-ip>:<node-port> <node-ip>:<node-port> <node-ip>:<node-port> ``` 将 `<node-ip>` 替换为你主机的 IP 地址, `<node-port>` 替换为容器中 Redis 主节点的端口(6379)。 例如: ```bash docker run -it --rm --network redis-net redis redis-cli --cluster create 172.18.0.2:6379 172.18.0.3:6379 172.18.0.4:6379 ``` 这将创建一个 Redis 集群,并将三个主节点添加到集群中。 5. 检查集群状态: ```bash docker run -it --rm --network redis-net redis redis-cli --cluster check <node-ip>:<node-port> ``` 例如: ```bash docker run -it --rm --network redis-net redis redis-cli --cluster check 172.18.0.2:6379 ``` 这将检查集群的状态,并输出每个节点的信息。 这样,你就成功使用 Docker 搭建了一个 Redis 集群。请根据你的实际需求进行相应的配置和调整。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值