【redis】redis重新创建集群

【redis】redis重新创建集群

【一】过程

【1】停止所有 Redis 集群节点

先把 3 台服务器上的 Redis 进程全部停止,防止清理文件时进程写入数据:

powershell 复制代码
# 登录每台Redis服务器,执行停止命令(替换为你的Redis安装路径)
# 方式1:用redis-cli停止(推荐,优雅关闭)
redis-cli -h 本机IP -p 6379 shutdown

# 方式2:若方式1失败,用kill命令(谨慎,避免数据丢失)
ps -ef | grep redis-server | grep -v grep | awk '{print $2}' | xargs kill -9

验证停止结果:ps -ef | grep redis-server 无输出则说明已停止。

【2】清理每个节点的集群残留数据

Redis 集群的元数据、槽位信息、数据会存在数据目录和集群配置文件中,必须全部删除,否则重新创建集群会读取旧数据。

先查看redis.conf,确认数据存储路径(每台节点都要查),确定数据存储路径后,删除data目录下的文件

powershell 复制代码
cd /home/redis/redis_home/6379/data && rm -rf *
cd /home/redis/redis_home/6380/data && rm -rf *

【3】重启服务

powershell 复制代码
cd /home/redis/redis_home/bin
./redis-server ../6379/conf/redis.conf && ./redis-server ../6380/conf/redis.conf

即使删除了文件,部分节点可能残留集群标识,执行重置命令确保节点回到 "单机" 状态:

powershell 复制代码
# 启动单个Redis节点(先不创建集群)
redis-server /etc/redis/redis.conf

# 连接节点,重置集群状态
redis-cli -h 本机IP -p 6379
127.0.0.1:6379> CLUSTER RESET HARD  # 硬重置,清除所有集群相关数据
127.0.0.1:6379> exit

# 再次停止该节点(准备重新创建集群)
redis-cli -h 本机IP -p 6379 shutdown

每台节点都要执行上述 "启动→重置→停止" 操作!

【4】创建集群,验证集群节点

如果配置了host就用host的名称,也可以直接在命令里使用ip

powershell 复制代码
./redis-cli -a Yatop@Bqd@2025 --cluster create redis1.yatop.com:6379 redis1.yatop.com:6380 redis2.yatop.com:6379 redis2.yatop.com:6380 redis3.yatop.com:6379 redis3.yatop.com:6380 --cluster-replicas 1
powershell 复制代码
cluster info
cluster nodes

【5】常见问题

(1)创建集群提示 "node is not empty":

原因是残留了数据 / 元数据,回到步骤 2 重新清理nodes-6379.conf和dump.rdb;

(2)集群创建后槽位未分配:

执行redis-cli --cluster fix 192.168.1.101:6379自动修复槽位;

(3)节点无法连接:

检查防火墙(开放 6379 和 16379 端口)、redis.conf中bind配置(建议设为 0.0.0.0)、protected-mode设为no。

【二】客户端连接集群并使用

【1】以redis集群方式进行连接

注意:-c 表示是以redis集群方式进行连接

powershell 复制代码
./redis-cli -h 192.168.0.102 -p 7001 -c

【2】查看集群状态

powershell 复制代码
cluster info

【3】查看集群中的节点

powershell 复制代码
cluster nodes

【4】添加数据并查看

从7001添加数据看看(如何选择和分配槽位slot的原理看一下)

从7002查询数据

【5】客户端工具连接

可以使用Another Redis Desktop Manager

下载地址:https://gitee.com/qishibo/AnotherRedisDesktopManager/releases

创建连接会话的时候,勾选cluster,标识连接redis集群,这样所有节点槽位的数据都可以查到了

相关推荐
Patrick_Wilson17 分钟前
router.replace 之后紧跟 reload,页面为什么无限刷新?
javascript·react.js·浏览器
小小小小宇32 分钟前
OpenMemory MCP
前端
和平宇宙1 小时前
AI笔记005. hermes-DeepSeek V4 Pro, 128K上下文引发的探索
前端·人工智能·笔记
IT_陈寒1 小时前
Redis持久化这个坑,我爬了一整天才出来
前端·人工智能·后端
naildingding2 小时前
3-ts接口 Interface
前端·typescript
mONESY2 小时前
JavaScript 栈、队列、数组与链表核心知识点总结
javascript·面试
小小前端仔LC2 小时前
Node.js + LangChain + React:搭建个人知识库(六)- “吃什么”项目实战:从700+菜谱入库到Taro H5端JSON渲染
前端·后端
ZengLiangYi2 小时前
TypeScript 项目配置:tsconfig、ESM、路径别名
javascript·typescript·aigc
晓13132 小时前
【Cocos Creator 3.x】篇——第二章 入门
前端·javascript·游戏引擎
想要成为糕糕手2 小时前
前端必修课:JavaScript 数组与数据结构底层逻辑全解析
javascript·数据结构·面试