Docker高级篇-Docker容器内Redis集群配置

本文详细介绍了如何在Docker环境下配置和管理一个三主三从的Redis集群,包括关闭防火墙、启动Docker服务、创建和连接容器、设置主从关系、检查集群状态、处理启动错误、实现读写路由、扩容与缩容等关键步骤,提供了具体的操作命令和流程。
摘要由CSDN通过智能技术生成

在这里插入图片描述

1、三主三从集成配置

1.1、关闭防火墙、启动docker服务

systemcl start docker 

1.2、新建6个docker容器实例

docker run -d --name redis-node-1 --net host --privileged=true -v /temp/redis/share/redis-node-1:/data redis --cluster-enabled yes --appendonly yes --port 6381

docker run -d --name redis-node-2 --net host --privileged=true -v /temp/redis/share/redis-node-2:/data redis --cluster-enabled yes --appendonly yes --port 6382

docker run -d --name redis-node-3 --net host --privileged=true -v /temp/redis/share/redis-node-3:/data redis --cluster-enabled yes --appendonly yes --port 6383

docker run -d --name redis-node-4 --net host --privileged=true -v /temp/redis/share/redis-node-4:/data redis --cluster-enabled yes --appendonly yes --port 6384

docker run -d --name redis-node-5 --net host --privileged=true -v /temp/redis/share/redis-node-5:/data redis --cluster-enabled yes --appendonly yes --port 6385

docker run -d --name redis-node-6 --net host --privileged=true -v /temp/redis/share/redis-node-6:/data redis --cluster-enabled yes --appendonly yes --port 6386

在这里插入图片描述

在这里插入图片描述
在这里插入图片描述

1.3、进入容器redis-node-1,构建主从关系

# 进入redis-node-1节点
docker exec -it redis-node-1 /bin/bash

# 构建主从关系,以下的ip可以在宿主主机上通过ifconfig查看(ens33)
redis-cli --cluster create 192.168.126.129:6381 192.168.126.129:6382 192.168.126.129:6383 192.168.126.129:6384 192.168.126.129:6385 192.168.126.129:6386 --cluster-replicas 1
  • 实际操作
    在这里插入图片描述
    在这里插入图片描述在这里插入图片描述

在这里插入图片描述
在这里插入图片描述

1.4、以redis-node-1为切入点,查看节点状态

redis-cli -p 6381

cluster info

cluster nodes

在这里插入图片描述在这里插入图片描述

在这里插入图片描述

1.5、如果docker启动报错

只需要重新启动即可。

docker start 容器ID

在这里插入图片描述

1.6、redis集群读写路由增强正确案例

redis-cli -p 6381 -c

FLUSHALL

在这里插入图片描述

1.7、查看集群信息

redis-cli --cluster check 192.168.126.129:6381

在这里插入图片描述

1.8、主从容错切换迁移

在这里插入图片描述

  • 先停止集群1(redis-node-1)
    在这里插入图片描述- 再次查看集群信息,发现节点1(redis-node-1)已经停止

在这里插入图片描述

  • 启动6382节点,我们发现此时6382变成了master,原来6381由master变成了salve

在这里插入图片描述

  • 再次启动redis-node-1,我们发现启动后的redis-node-1依然是slave,而redis-node-2是master

#启动redis-node-1
docker start redis-node-1

(
#停止redis-node-1的命令
docker stop redis-node-1
)

#查看集群状态
cluster nodes

在这里插入图片描述
在这里插入图片描述

1.9、主从扩容

在这里插入图片描述- 新建6387、6388两个节点+新建后启动+查看是否有8个节点

docker run -d --name redis-node-7 --net host --privileged=true -v /temp/redis/share/redis-node-7:/data redis --cluster-enabled yes --appendonly yes --port 6387

docker run -d --name redis-node-8 --net host --privileged=true -v /temp/redis/share/redis-node-8:/data redis --cluster-enabled yes --appendonly yes --port 6388

docker ps

在这里插入图片描述

  • 进入6387容器实例内部
docker exec -it redis-node-7 /bin/bash

在这里插入图片描述

  • 将新增的6387节点作为master加入原集群
# 6381相当于6387的引路人,将6387推荐进入集群
redis-cli --cluster add-node 192.168.126.129:6387 192.168.126.129:6381

在这里插入图片描述
在这里插入图片描述在这里插入图片描述

  • 检查集群情况第1次
redis-cli --cluster check 192.168.126.129:6387

在这里插入图片描述

  • 重新分派槽号
redis-cli --cluster reshard 192.168.126.129:6381

在这里插入图片描述在这里插入图片描述在这里插入图片描述

  • 检查集群情况第2次
redis-cli --cluster check 192.168.126.129:6387

在这里插入图片描述

  • 原来的三个主机都分出来相同的槽点数给新的主节点,并不是全部洗牌,重新分配

在这里插入图片描述

  • 为主节点6387分配从节点6388
# redis-cli --cluster add-node 192.168.126.129:6388 192.168.126.129:6387 --cluster-slave --cluster-master-id 主节点7容器ID

redis-cli --cluster add-node 192.168.126.129:6388 192.168.126.129:6387 --cluster-slave --cluster-master-id a7e68cb432df591df220ad76700ea6bb43093ddc

在这里插入图片描述
在这里插入图片描述

  • 检查集群情况第3次
redis-cli --cluster check 192.168.126.129:6388

在这里插入图片描述

1.10、主从缩容

在这里插入图片描述
-获取redis-node-7的容器ID

redis-cli --cluster check 192.168.126.129:6387
  • 将6388删除

# redis-cli --cluster del-node 192.168.126.129:6388 容器ID

redis-cli --cluster del-node 192.168.126.129:6388 19ad55089a4443f5c17260311ab4ddc50d7981d2

在这里插入图片描述

在这里插入图片描述

  • 检查集群情况第一次:只剩下7个节点
    在这里插入图片描述
  • 重新分配槽点,本案例中时将空余出来的槽点全部分配给节点1
redis-cli --cluster reshard 192.168.126.129:6381

  • 检查集群情况第2次:6387的槽点数已全部分出,目前6387槽点数为0

在这里插入图片描述
在这里插入图片描述

  • 将6387节点删除
redis-cli --cluster del-node 192.168.126.129:6387 容器ID

在这里插入图片描述在这里插入图片描述

  • 第三次检查集群情况,又变回了三主三从

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值