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

相关推荐
We་ct2 分钟前
LeetCode 67. 二进制求和:详细题解+代码拆解
前端·数据结构·算法·leetcode·typescript
还是大剑师兰特2 分钟前
为什么要用 import.meta.glob 加载 SVG 图标库
开发语言·前端·javascript
渣渣xiong4 分钟前
《从零开始:前端转型AI agent直到就业第三天》
前端·ai编程
qiuge6784 分钟前
一网打尽react手写题(上)
前端·javascript·react.js
zs宝来了4 分钟前
Redis 持久化机制:RDB 和 AOF 实现原理对比
redis·持久化·aof·源码解析·rdb
天若有情6737 分钟前
从C++ RefInt到JS Object.defineProperty:吃透响应式监听的本质(学生视角)
开发语言·javascript·c++
rhythmcc10 分钟前
【npm&pnpm】基本使用
前端·npm·node.js
zs宝来了11 分钟前
Redis 过期策略与内存淘汰算法全解析
redis·lfu·lru·过期策略·内存淘汰
天天向上102414 分钟前
vue3 el-date-picker 需求是想既可以输入,也可以选择, 且开始时间不能大于结束时间, 当不符合条件时border变成红色
前端·javascript·vue.js
kyle~15 分钟前
前端框架---React
前端·react.js·前端框架