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

Docker容器内Redis集群配置

  • 1、三主三从集成配置
    • 1.1、关闭防火墙、启动docker服务
    • 1.2、新建6个docker容器实例
    • 1.3、进入容器redis-node-1,构建主从关系
    • 1.4、以redis-node-1为切入点,查看节点状态
    • 1.5、如果docker启动报错
    • 1.6、redis集群读写路由增强正确案例
    • 1.7、查看集群信息
    • 1.8、主从容错切换迁移
    • 1.9、主从扩容
    • 1.10、主从缩容

Docker高级篇-Docker容器内Redis集群配置_第1张图片

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

在这里插入图片描述

Docker高级篇-Docker容器内Redis集群配置_第2张图片
Docker高级篇-Docker容器内Redis集群配置_第3张图片

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
  • 实际操作
    Docker高级篇-Docker容器内Redis集群配置_第4张图片
    Docker高级篇-Docker容器内Redis集群配置_第5张图片在这里插入图片描述

Docker高级篇-Docker容器内Redis集群配置_第6张图片
Docker高级篇-Docker容器内Redis集群配置_第7张图片

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

redis-cli -p 6381

cluster info

cluster nodes

Docker高级篇-Docker容器内Redis集群配置_第8张图片Docker高级篇-Docker容器内Redis集群配置_第9张图片

Docker高级篇-Docker容器内Redis集群配置_第10张图片

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

Docker高级篇-Docker容器内Redis集群配置_第11张图片

1.8、主从容错切换迁移

Docker高级篇-Docker容器内Redis集群配置_第12张图片

  • 先停止集群1(redis-node-1)
    Docker高级篇-Docker容器内Redis集群配置_第13张图片- 再次查看集群信息,发现节点1(redis-node-1)已经停止

Docker高级篇-Docker容器内Redis集群配置_第14张图片

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

Docker高级篇-Docker容器内Redis集群配置_第15张图片

  • 再次启动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

Docker高级篇-Docker容器内Redis集群配置_第16张图片
在这里插入图片描述

1.9、主从扩容

Docker高级篇-Docker容器内Redis集群配置_第17张图片- 新建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

Docker高级篇-Docker容器内Redis集群配置_第18张图片

  • 进入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

Docker高级篇-Docker容器内Redis集群配置_第19张图片
Docker高级篇-Docker容器内Redis集群配置_第20张图片在这里插入图片描述

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

Docker高级篇-Docker容器内Redis集群配置_第21张图片

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

Docker高级篇-Docker容器内Redis集群配置_第22张图片Docker高级篇-Docker容器内Redis集群配置_第23张图片在这里插入图片描述

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

Docker高级篇-Docker容器内Redis集群配置_第24张图片

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

Docker高级篇-Docker容器内Redis集群配置_第25张图片

  • 为主节点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

Docker高级篇-Docker容器内Redis集群配置_第26张图片
Docker高级篇-Docker容器内Redis集群配置_第27张图片

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

Docker高级篇-Docker容器内Redis集群配置_第28张图片

1.10、主从缩容

Docker高级篇-Docker容器内Redis集群配置_第29张图片
-获取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

在这里插入图片描述

Docker高级篇-Docker容器内Redis集群配置_第30张图片

  • 检查集群情况第一次:只剩下7个节点
    Docker高级篇-Docker容器内Redis集群配置_第31张图片
  • 重新分配槽点,本案例中时将空余出来的槽点全部分配给节点1
redis-cli --cluster reshard 192.168.126.129:6381

Docker高级篇-Docker容器内Redis集群配置_第32张图片

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

Docker高级篇-Docker容器内Redis集群配置_第33张图片
Docker高级篇-Docker容器内Redis集群配置_第34张图片

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

Docker高级篇-Docker容器内Redis集群配置_第35张图片在这里插入图片描述

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

Docker高级篇-Docker容器内Redis集群配置_第36张图片

你可能感兴趣的:(Docker,docker,redis,容器)