docker搭建redis集群

docker搭建redis集群

1、新建6个docker-redis容器实例

docker run -d --name redis-node-1 --net host --privileged=true -v /data/redis/share/redis-node-1:/data redis:6.0.8 --cluster-enabled yes --appendonly yes --port 6381
docker run -d --name redis-node-2 --net host --privileged=true -v /data/redis/share/redis-node-2:/data redis:6.0.8 --cluster-enabled yes --appendonly yes --port 6382
docker run -d --name redis-node-3 --net host --privileged=true -v /data/redis/share/redis-node-3:/data redis:6.0.8 --cluster-enabled yes --appendonly yes --port 6383
docker run -d --name redis-node-4 --net host --privileged=true -v /data/redis/share/redis-node-4:/data redis:6.0.8 --cluster-enabled yes --appendonly yes --port 6384
docker run -d --name redis-node-5 --net host --privileged=true -v /data/redis/share/redis-node-5:/data redis:6.0.8 --cluster-enabled yes --appendonly yes --port 6385
docker run -d --name redis-node-6 --net host --privileged=true -v /data/redis/share/redis-node-6:/data redis:6.0.8 --cluster-enabled yes --appendonly yes --port 6386

2、进入容器redis-node-1,构建集群关系

docker exec -it redis-node-1 /bin/bash
redis-cli --cluster create 172.17.0.3:6381 172.17.0.3:6382 172.17.0.3:6383 172.17.0.3:6384 172.17.0.3:6385 172.17.0.3:6386 --cluster-replicas 1

–cluster-replicas 1:表示为每个master创建一个slave节点

3、查看集群状态

以6381为切入点

cluster info
cluster nodes

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

MS
15
26
34

4、用集群方式进入redis-node-1

刚才是用单机方式连接:redis-cli -p 6381,这样存值可能会存不进去。因为1号机的哈希槽范围为0-5460,如果key超过了这个范围,会报错。如图,哈希槽位为12706
在这里插入图片描述
此时我们需要用集群方式连接:redis-cli -p 6387 -c
在这里插入图片描述
存入成功!

5、查看集群信息

redis-cli --cluster check 172.17.0.3:6381

在这里插入图片描述

6、主从扩容

新建6387、6388两个节点

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

在这里插入图片描述

7、将新建的两个节点加入集群

进入6387容器实例内部

docker exec -it redis-node-7 /bin/bash

将新增的6387节点(空槽号)作为master节点加入原集群

redis-cli --cluster add-node 172.17.0.3:6387 172.17.0.3:6381

在这里插入图片描述

查看集群(第一次)

redis-cli --cluster check 172.17.0.3:6381

在这里插入图片描述
可以看到,此时6387已加入集群,但是还没有分配到槽位
重新分配槽号

redis-cli --cluster reshard 172.17.0.3:6381

在这里插入图片描述
查看集群(第二次)

redis-cli --cluster check 172.17.0.3:6381

在这里插入图片描述
问:为什么6387是3个新区间,以前的还是连续的?
答:重新分配成本太高,所以前3家各自匀出来一部分,从6387/6382/6383三个旧节点分别匀出1364个槽位给新节点6387

为主节点6387分配从节点6388

redis-cli --cluster add-node 172.17.0.3:6388 172.17.0.3:6387 --cluster-slave --cluster-master-id 147584d20cc9b535a56e7ceb670188669663a052

在这里插入图片描述
查看集群(第三次)

redis-cli --cluster check 172.17.0.3:6381

在这里插入图片描述

8、主从缩容

步骤:先清除从节点6388,槽号从新分配,再删除6387,恢复3主3从
删除从节点6388

redis-cli --cluster del-node 172.17.0.3:6388 068637b2c91a38970653aabf0c257c5c2a1cf092

在这里插入图片描述
在这里插入图片描述
检查发现只剩7台,删除从节点6388成功!
将6387的槽号清空,重新分配,本例将清出来的槽号都给6381

redis-cli --cluster reshard 172.17.0.3:6381

在这里插入图片描述
检查集群情况,可以看到,6381现在又8192个槽位,6387为0个槽位
在这里插入图片描述
删除主节点6387

redis-cli --cluster del-node 172.17.0.3:6387 147584d20cc9b535a56e7ceb670188669663a052

在这里插入图片描述
删除成功!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要使用 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、付费专栏及课程。

余额充值