【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集群,这样所有节点槽位的数据都可以查到了

相关推荐
Detachym2 小时前
InsightFlow:基于 Spring Boot+Redis+Docker 的实时监控告警系统全流程开发与部署
spring boot·redis·docker
卡皮巴拉c992 小时前
基于 wujie.js 进行微前端融合
前端
来碗疙瘩汤2 小时前
深入解析 Vue 包:`vue` 究竟导出了什么?
前端
我命由我123452 小时前
React - ref、回调 ref 回调执行次数的问题、createRef 函数、事件处理
前端·javascript·react.js·前端框架·html·html5·js
我命由我123452 小时前
React - 收集表单元素、收集表单元素优化、生命周期(旧)、生命周期(新)
前端·javascript·react.js·前端框架·html·html5·js
SuperEugene2 小时前
Monorepo + pnpm workspace 落地实操:Vue 中后台多项目 / 组件库 / 公共包管理|Vue 工程化篇
前端·javascript·vue.js·pnpm·vite·monorepo
We་ct2 小时前
JSX & ReactElement 核心解析
前端·react.js·面试·架构·前端框架·reactjs·个人开发
白中白121382 小时前
杂七杂八补充系列
开发语言·前端·javascript
乄bluefox2 小时前
Redis Pipeline 实战:Spring Data Redis 批量写入最佳实践
java·redis·spring