docker部署的redis集群 添加节点(扩容)

本文涉及的产品
Redis 开源版,标准版 2GB
推荐场景:
搭建游戏排行榜
云数据库 Tair(兼容Redis),内存型 2GB
简介: 这篇博文说一下如何在集群基础上继续添加节点,也就是给集群扩容



这篇博文说一下如何在集群基础上继续添加节点,也就是给集群扩容


博文中的命令出现的 111.111.111.111 均换成实际 IP 执行


创建要添加的一主一从容器

这里创建一个6377主节点和一个6378从节点


docker run -d --name redis-node7 --net host --privileged=true -v /usr/local/redis/node7:/data redis:6.0.8 --cluster-enabled yes --appendonly yes --port 6377

docker run -d --name redis-node8 --net host --privileged=true -v /usr/local/redis/node8:/data redis:6.0.8 --cluster-enabled yes --appendonly yes --port 6378


然后别忘记打开这两个端口和对应的16377 16378通信端口


将新增的6377作为 master 节点加入集群

进入6377节点


docker exec -it redis-node7 /bin/bash

执行添加命令


redis-cli --cluster add-node 111.111.111.111:6377 111.111.111.111:6374

意思是把6377添加到6374领头的主节点集群,执行之后出现一大段内容,有下图内容表示添加成功



检查集群情况,可以发现已经有6377主节点了,但是还没有分配槽位(下图第四行中 0 slots | 0 slaves)


redis-cli --cluster check 111.111.111.111:6371


集群重新分配槽位

执行重新分配槽位命令(目前还是在6377容器里面,在其他节点执行也是没问题的 )


redis-cli --cluster reshard 111.111.111.111:6371

执行之后会出现下图内容,问你1到16384分配多少,这里因为是4个主节点 所以直接使用16384除以4得到4096,输入4096回车



然后又会问你节点的ID,这里一定要输入上图红框位置的6377节点的ID(肯定跟我图上的不一样,填你实际的ID)。填完之后又会问你是处理单个节点还是所有节点,这里输入all 回车



开始分配后,中途会再询问你一次,是否继续执行重新分配计划,输入yes回车。等他继续分配完成。再次使用check命令查看集群情况



可以看到四个主节点都是4096个槽位,但并不是重新分成四份分配的,而是在原来三个节点槽位中挨个分了一部分(大概1364个)给新节点。


因为之前节点已经存有数据了,如果重新分配成本太高,所以就采用这种形式


给6377节点挂一个6378从节点

redis-cli --cluster add-node 111.111.111.111:6378 111.111.111.111:6377 --cluster-slave --cluster-master-id fdb615eb6c86ec8246739112b6cc89679b37f58b

命令最后的id是6377主节点的节点id,也就是上一步分配槽位时填的那个id


再次使用check命令查看,可以看到已经是4主4从了

   



到此就完成了从原来的3主3从集群扩容到4主4从集群


有扩容就有缩容,下篇博文完成删除节点 缩容操作:点这里


相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore     ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库 ECS 实例和一台目标数据库 RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
相关文章
|
2月前
|
Kubernetes NoSQL Redis
k8s快速部署Redis单机
k8s快速部署Redis单机
|
1月前
|
NoSQL 关系型数据库 Redis
mall在linux环境下的部署(基于Docker容器),Docker安装mysql、redis、nginx、rabbitmq、elasticsearch、logstash、kibana、mongo
mall在linux环境下的部署(基于Docker容器),docker安装mysql、redis、nginx、rabbitmq、elasticsearch、logstash、kibana、mongodb、minio详细教程,拉取镜像、运行容器
mall在linux环境下的部署(基于Docker容器),Docker安装mysql、redis、nginx、rabbitmq、elasticsearch、logstash、kibana、mongo
|
2月前
|
NoSQL Redis 数据安全/隐私保护
深入探索利用Docker安装Redis
【8月更文挑战第27天】
91 2
|
2月前
|
负载均衡 调度 Docker
|
2月前
|
Kubernetes NoSQL Redis
【Azure Redis】部署在AKS中的应用连接Redis时候出现Unable to connect to Redis server
【Azure Redis】部署在AKS中的应用连接Redis时候出现Unable to connect to Redis server
【Azure Redis】部署在AKS中的应用连接Redis时候出现Unable to connect to Redis server
|
2月前
|
缓存 NoSQL Redis
【Azure Redis 缓存】遇见Azure Redis不能创建成功的问题:至少一个资源部署操作失败,因为 Microsoft.Cache 资源提供程序未注册。
【Azure Redis 缓存】遇见Azure Redis不能创建成功的问题:至少一个资源部署操作失败,因为 Microsoft.Cache 资源提供程序未注册。
|
2月前
|
存储 人工智能 NoSQL
AI自动化!redis高效部署脚本
AI自动化!redis高效部署脚本
37 0
|
21天前
|
canal 缓存 NoSQL
Redis缓存与数据库如何保证一致性?同步删除+延时双删+异步监听+多重保障方案
根据对一致性的要求程度,提出多种解决方案:同步删除、同步删除+可靠消息、延时双删、异步监听+可靠消息、多重保障方案
Redis缓存与数据库如何保证一致性?同步删除+延时双删+异步监听+多重保障方案
|
2月前
|
缓存 NoSQL Java
Redis深度解析:解锁高性能缓存的终极武器,让你的应用飞起来
【8月更文挑战第29天】本文从基本概念入手,通过实战示例、原理解析和高级使用技巧,全面讲解Redis这一高性能键值对数据库。Redis基于内存存储,支持多种数据结构,如字符串、列表和哈希表等,常用于数据库、缓存及消息队列。文中详细介绍了如何在Spring Boot项目中集成Redis,并展示了其工作原理、缓存实现方法及高级特性,如事务、发布/订阅、Lua脚本和集群等,帮助读者从入门到精通Redis,大幅提升应用性能与可扩展性。
60 0
|
22天前
|
存储 NoSQL Redis
SpringCloud基础7——Redis分布式缓存,RDB,AOF持久化+主从+哨兵+分片集群
Redis持久化、RDB和AOF方案、Redis主从集群、哨兵、分片集群、散列插槽、自动手动故障转移
SpringCloud基础7——Redis分布式缓存,RDB,AOF持久化+主从+哨兵+分片集群
下一篇
无影云桌面