Redis 7.x 系列【30】集群管理命令
有道无术,术尚可求,有术无道,止于术。
本系列Redis 版本 7.2.5
源码地址:https://gitee.com/pearl-organization/study-redis-demo
文章目录
- 1. 概述
 - 2. 集群信息
 - 2.1 CLUSTER INFO
 
- 3. 节点管理
 - 3.1 CLUSTER MYID
 - 3.2 CLUSTER NODES
 - 3.3 CLUSTER REPLICAS
 - 3.4 CLUSTER FORGET
 - 3.5 CLUSTER MEET
 
- 4. 哈希槽管理
 - 4.1 CLUSTER SLOTS
 - 4.2 CLUSTER KEYSLOT
 - 4.3 CLUSTER COUNTKEYSINSLOT
 - 4.4 CLUSTER DELSLOTS
 - 4.5 CLUSTER ADDSLOTS
 - 4.6 CLUSTER SETSLOT
 - 4.7 CLUSTER FLUSHSLOTS
 
- 5. 其他
 - 5.1 CLUSTER FAILOVER
 
1. 概述
集群管理命令是用于管理和维护 Redis 集群,允许用户执行如查看集群信息、添加或删除节点、重新分片等操作。
所有命令:
| 命名 | 描述 | 
|---|---|
| ASKING | 用于 ASK 重定向 | 
| CLUSTER ADDSLOTS | 将一个或多个槽指派给当前节点 | 
| CLUSTER ADDSLOTSRANGE | 将指定范围内的槽指派给当前节点 | 
| CLUSTER BUMPEPOCH | 提升集群的 config epoch | 
| CLUSTER COUNT-FAILURE | 返回指定节点当前未过期的失败报告的数量 | 
| CLUSTER COUNTKEYSINSLOT | 返回指定槽中键的数量 | 
| CLUSTER DELSLOTS | 移除一个或多个槽对当前节点的指派 | 
| CLUSTER DELSLOTSRANGE | 移除范围内的槽对当前节点的指派 | 
| CLUSTER FAILOVER | 手动触发故障转移 | 
| CLUSTER FLUSHSLOTS | 移除指派给当前节点的所有槽,让当前节点变成一个没有指派任何槽的节点 | 
| CLUSTER FORGET | 从集群中移除指定节点ID的节点 | 
| CLUSTER GETKEYSINSLOT | 返回指定槽中的键 | 
| CLUSTER INFO | 打印集群的详细信息,包括集群状态、节点数量、槽分配情况 | 
| CLUSTER KEYSLOT | 返回指定键存储的哈希槽 | 
| CLUSTER LINKS | 输出所有集群节点之间对等连接信息 | 
| CLUSTER MEET | 将指定IP和端口的节点添加到集群中 | 
| CLUSTER MYID | 查看当前节点的运行ID | 
| CLUSTER MYSHARDID | 查看当前节点的分片ID | 
| CLUSTER NODES | 列出集群当前已知的所有节点及其相关信息 | 
| CLUSTER REPLICAS | 返回指定主节点进行复制的从节点列表 | 
| CLUSTER REPLICATE | 将当前节点设置为指定节点ID的节点的从节点 | 
| CLUSTER RESET | 重置集群节点的状态 | 
| CLUSTER SAVECONFIG | 将节点的配置文件保存到硬盘上 | 
| CLUSTER SET-CONFIG-EPOCH | 在新节点中设置特定的配置时期 | 
| CLUSTER SETSLOT | 改变接收节点中哈希槽的状态 | 
| CLUSTER SHARDS | 获取集群中所有分片信息 | 
| CLUSTER SLAVES | 查看指定主节点的所有从节点列表 | 
| CLUSTER SLOTS | 查询集群哈希槽与节点映射关系 | 
| READONLY | 在从节点上开启只读模式,读取可能不是最新的数据 | 
| READWRITE | 取消之前通过 READONLY 命令设置的只读模式 | 
2. 集群信息
2.1 CLUSTER INFO
获取集群的当前状态和各种统计信息。
关键信息说明:
cluster_state:表示集群的当前状态,ok表示集群运行正常,其他值可能表示集群存在问题cluster_slots_assigned:已分配的槽位数量,理想情况下应为16384,表示所有槽位都已被分配。cluster_slots_ok:正常运行的槽位数量,应与cluster_slots_assigned相同,除非有槽位因故障而无法正常工作。cluster_slots_pfail:疑似失败的槽位数量,这些槽位可能由于网络问题等原因暂时无法访问。cluster_slots_fail:运行失败的槽位数量,这些槽位由于某种原因(如节点故障)已经完全无法访问。cluster_known_nodes:集群中已知节点的数量,这个数量应等于集群中所有正常工作的节点数。
示例:
主节点(192.168.56.101:6381)>cluster info
"cluster_state:ok
cluster_slots_assigned:16384 
cluster_slots_ok:16384
cluster_slots_pfail:0
cluster_slots_fail:0
cluster_known_nodes:6 
cluster_size:3  
cluster_current_epoch:9
cluster_my_epoch:3
cluster_stats_messages_ping_sent:42283
cluster_stats_messages_pong_sent:42739
cluster_stats_messages_fail_sent:4
cluster_stats_messages_update_sent:3
cluster_stats_messages_sent:85029
cluster_stats_messages_ping_received:42739
cluster_stats_messages_pong_received:50471
cluster_stats_messages_fail_received:1
cluster_stats_messages_received:93211
total_cluster_links_buffer_limit_exceeded:0
"
 
3. 节点管理
3.1 CLUSTER MYID
查看当前节点的运行 ID (Run ID),运行 ID 是集群中每个节点唯一的标识符,用于集群内部的管理和通信。在节点重启后可能会改变,因此它不能作为节点的永久标识符。但在节点运行期间,运行 ID 是唯一的,并且不会改变。在进行集群管理操作时,如添加、删除节点或进行故障转移等会用到该 ID。
示例:
主节点(192.168.56.101:6381)>CLUSTER MYID
"9f9c30c3f73106e256fdec27264fc8129e1287fd"
 
3.2 CLUSTER NODES
查看集群当前已知的所有节点以及节点信息,对于集群的管理、监控和故障排查都非常重要。
示例:
主节点(192.168.56.101:6381)>CLUSTER NODES
"9f9c30c3f73106e256fdec27264fc8129e1287fd 192.168.56.101:6381@16381 myself,master - 0 1721405084000 3 connected 12288-16383
e909dc338f4c2fc7687cf4426d3b95956a90a8a8 192.168.56.101:6380@16380 master - 0 1721405088116 9 connected 0-1364 5461-12287
ce27fa445e987f75bddeeb68fc6fe440678ad1bb 192.168.56.101:6382@16382 master - 0 1721405087000 7 connected 1365-5460
0f1d8d6459ac4252636cb4b8e1764de9e277411c 192.168.56.101:6390@16390 slave 9f9c30c3f73106e256fdec27264fc8129e1287fd 0 1721405088000 3 connected
724c7b874dc0c37a462cd5ab59325203344f8008 192.168.56.101:6379@16379 slave ce27fa445e987f75bddeeb68fc6fe440678ad1bb 0 1721405090177 7 connected
b5bde236f14f21f530a7095aaef3a98109009324 192.168.56.101:6383@16383 slave e909dc338f4c2fc7687cf4426d3b95956a90a8a8 0 1721405089144 9 connected"
 
各部分信息说明:
ce27fa445e987f75bddeeb68fc6fe440678ad1bb:节点ID,每个节点的唯一标识符192.168.56.101:6382@16382:节点的IP地址、客户端连接端口号、集群总线端口号,用于节点间的通信master:节点在集群中的角色,可以是主节点(master)或从节点(slave)- 0:节点标记,- 0表示没有特殊的标记,在某些情况下,这里可能会显示fail、myself或其他状态标志1721405087000:节点最后一次发送心跳消息到当前节点的时间戳(以毫秒为单位)7:配置纪元(config epoch)的编号,是一个递增的计数器,用于在集群重新配置(如故障转移)时跟踪集群的状态connected:节点的当前状态,如在线(connected)、疑似失败(pfail)、失败(fail)等1365-5460:分配的哈希槽
3.3 CLUSTER REPLICAS
返回主节点进行复制的从节点列表。
示例:
主节点(192.168.56.101:6381)>CLUSTER REPLICAS 9f9c30c3f73106e256fdec27264fc8129e1287fd1)  "0f1d8d6459ac4252636cb4b8e1764de9e277411c 192.168.56.101:6390@16390 slave 9f9c30c3f73106e256fdec27264fc8129e1287fd 0 1721406870213 3 connected"
 
3.4 CLUSTER FORGET
从集群中移除指定的节点。
示例:
主节点(192.168.56.101:6381)>CLUSTER FORGET e909dc338f4c2fc7687cf4426d3b95956a90a8a8
"OK"
 
注意事项:
- 只是在集群中移除,并不会关闭该节点或停止其运行
 - 请确保被移除的节点确实不再需要参与集群的运行,并且已经做好了相应的数据备份和迁移工作
 
查看集群信息:

3.5 CLUSTER MEET
用于将支持集群的不同 Redis 节点连接成一个工作集群。
节点默认情况下不相互信任,被视为未知节点,需要让其他节点接受并加入到集群,目前提供了两种方式:
CLUSTER MEET:强制一个节点与另一个节点建立联系Gossip:使用流言协议进行传播
示例,将上面被移除的节点重新加入到集群:
主节点(192.168.56.101:6381)>CLUSTER MEET 192.168.56.101 6380
"OK"
 
4. 哈希槽管理
4.1 CLUSTER SLOTS
获取集群中所有哈希槽的分配情况。返回值为嵌套数组,每个嵌套数组包含一个哈希槽的范围,以及负责该槽范围的节点的 IP 地址和端口号。
示例:
主节点(192.168.56.101:6381)>CLUSTER SLOTS1)    1)   "0"2)   "1364"3)      1)    "192.168.56.101"2)    "6380"3)    "e909dc338f4c2fc7687cf4426d3b95956a90a8a8"4)    4)      1)    "192.168.56.101"2)    "6383"3)    "b5bde236f14f21f530a7095aaef3a98109009324"4)    2)    1)   "1365"
 
4.2 CLUSTER KEYSLOT
返回给定 key 存储的哈希槽编号。
示例:
主节点(192.168.56.101:6381)>CLUSTER KEYSLOT aa
"1180"
 
4.3 CLUSTER COUNTKEYSINSLOT
返回指定哈希槽中 key 的数量。只查询连接节点的本地数据集,如果指定的 slot 被分配在别的节点上,就会返回 0。
示例:
主节点(192.168.56.101:6381)>CLUSTER COUNTKEYSINSLOT 1180
"1"
 
4.4 CLUSTER DELSLOTS
将接收命令的节点上的一组哈希槽进行移除。
示例:
主节点(192.168.56.101:6381)>CLUSTER DELSLOTS 12288 12299 12300 
"OK"
 
4.5 CLUSTER ADDSLOTS
将一组哈希槽分配给接收命令的节点。如果命令执行成功,该节点将指定的哈希槽映射到自己身上,并开始广播新的配置。
注意事项:
- 如果哈希槽已被分配给其他节点,会抛出异常
 - 如果同一个槽位被多次指定,则该命令会失败
 
示例,将上面移除的哈希槽,重新分配给当前节点:
主节点(192.168.56.101:6381)>CLUSTER ADDSLOTS 12288 12299 12300
"OK"
 
4.6 CLUSTER SETSLOT
用于重新分片哈希槽,以不同的方式改变接收节点中哈希槽的状态。
命令格式:
CLUSTER SETSLOT slot <IMPORTING node-id | MIGRATING node-id |NODE node-id | STABLE>
 
子命令说明:
MIGRATING:将哈希槽设置为迁移状态。通常用于在源节点上,表明该槽位的数据正在迁移到其他节点。IMPORTING:将哈希槽设置为导入状态。这通常用于在目标节点上设置槽位,表明该节点正在从其他节点导入数据。STABLE:清除哈希槽上的任何导入/迁移状态。这通常用于在迁移过程完成后,将槽位状态重置为稳定状态。NODE:将哈希槽分配到另一个节点。可能存在一些限制,建议使用CLUSTER ADDSLOTS命令来分配槽位。
4.7 CLUSTER FLUSHSLOTS
移除指派给当前节点的所有槽,让当前节点变成一个没有指派任何槽的节点。
示例:
 
5. 其他
5.1 CLUSTER FAILOVER
用于手动触发故障转移过程,强制将从节点升级为主节点。手动故障转移是一种特殊的故障转移方式,它通常在没有实际故障发生时执行,但我们希望以安全的方式(没有任何数据丢失的风险)将当前的主节点与其从节点之一进行交换。
命令格式:
CLUSTER FAILOVER [FORCE | TAKEOVER]
 
参数说明:
- 无参:尝试与当前的主节点进行协商,并遵循标准的故障转移流程
 FORCE:从节点会跳过与主节点的协商步骤,并尽快启动故障转移过程TAKEOVER:它允许从节点单方面地成为主节点,而不需要等待集群中其他主节点的授权或投票
注意事项:
- 只能在从节点上执行
 FORCE和TAKEOVER参数会绕过正常的故障转移流程,可能会导致意外的后果- 建议自动处理故障转移,而不是手动干预
 
示例,让从节点升级为主节点:

相关文章:
Redis 7.x 系列【30】集群管理命令
有道无术,术尚可求,有术无道,止于术。 本系列Redis 版本 7.2.5 源码地址:https://gitee.com/pearl-organization/study-redis-demo 文章目录 1. 概述2. 集群信息2.1 CLUSTER INFO 3. 节点管理3.1 CLUSTER MYID3.2 CLUSTER NODES3…...
将YOLOv8模型从PyTorch的.pt格式转换为TensorRT的.engine格式
TensorRT是由NVIDIA开发的一款高级软件开发套件(SDK),专为高速深度学习推理而设计。它非常适合目标检测等实时应用。该工具包可针对NVIDIA GPU优化深度学习模型,从而实现更快、更高效的运行。TensorRT模型经过TensorRT优化,包括层融合(layer …...
Hello SLAM(在Linux中实现第一个C++程序)
首先需要安装vim编辑器,输入命令 sudo apt install vim 在Ubuntu上安装好vim编辑器后,创建路径(/home/slambook/ch2),在该路径下创建一个cpp文档(touch hello.c),通过vim编辑器进行…...
IPD推行成功的核心要素(十五)项目管理提升IPD相关项目交付效率和用户体验
研发项目往往包含很多复杂的流程和具体的细节。因此,一套完整且标准的研发项目管理制度和流程对项目的推进至关重要。研发项目管理是成功推动创新和技术发展的关键因素。然而在实际管理中,研发项目管理常常面临着需求不确定、技术风险、人员素质、成本和…...
C++ 鼠标轨迹API【神诺科技SDK】
一.鼠标轨迹模拟简介 传统的鼠标轨迹模拟依赖于简单的数学模型,如直线或曲线路径。然而,这种方法难以捕捉到人类操作的复杂性和多样性。AI大模型的出现,使得神诺科技 能够通过深度学习技术,学习并模拟更自然的鼠标移动行为。 二.…...
设计模式|观察者模式
观察者模式是一种行为设计模式,它定义了一种一对多的依赖关系,让多个观察者对象同时监听某一个主题对象。当主题对象发生变化时,它的所有观察者都会收到通知并更新。观察者模式常用于实现事件处理系统、发布-订阅模式等。在项目中,…...
python自动化运维 通过paramiko库和time库实现服务器自动化管理
目录 一.前言 二. 代码实现以及解析 2.1导入必要的库 2.2定义服务器信息 2.3创建 SSH 客户端连接函数 2.4执行远程命令函数 2.5获取系统信息函数 2.6重启服务函数 2.7 主函数 三.致谢 一.前言 在数字化时代,IT 基础设施的规模和复杂性不断增长&am…...
HTML常用的转义字符——怎么在网页中写“<div></div>”?
一、问题描述 如果需要在网页中写“<div></div>”怎么办呢? 使用转义字符 如果直接写“<div></div>”,编译器会把它翻译为块,类似的,其他的标签也是如此,所以如果要在网页中写类似于“<div…...
shell-awk文本处理工具
1、awk概述 AWK 是一种处理文本文件的语言,是一个强大的文本分析工具。 它是专门为文本处理设计的编程语言,也是行处理软件,通常用于扫描、过滤、统计汇总工作 数据可以来自标准输入也可以是管道或文件 在 linux 上常用的是 gawk,awk …...
如何在测试中保护用户隐私!
在当今数据驱动的时代,用户隐私保护成为了企业和开发团队关注的焦点。在软件测试过程中,处理真实用户数据时保护隐私尤为重要。本文将介绍如何在测试中保护用户隐私,并提供具体的方案和实战演练。 用户隐私保护的重要性 用户隐私保护不仅是法…...
ARCGIS PRO DSK GraphicsLayer创建文本要素
一、判断GraphicsLayer层【地块注记】是否存在,如果不存在则新建、如果存在则删除所有要素 Dim GraphicsLayer pmap.GetLayersAsFlattenedList().OfType(Of ArcGIS.Desktop.Mapping.GraphicsLayer).FirstOrDefault() 获取当前map对象中的GetLayer图层 Await Queue…...
看板项目之vue代码分析
目录: Q1、vue项目怎么实现的输入localhost:8080就能自动跳到index页面Q2、组合饼状图如何实现Q3、vue项目如何实现环境的切换Q4、vue怎么实现vue里面去调用js文件里面的函数 Q1、vue项目怎么实现的输入localhost:8080就能自动跳到index页面 …...
lua 游戏架构 之 游戏 AI (七)ai_dead
定义一个名为ai_dead的类,继承自ai_base类。这个类用于处理游戏中AI在死亡状态下的行为逻辑。以下是对代码的具体解释: 1. **引入基类**: - 使用require函数引入ai_base类,作为基础类。 2. **定义ai_dead类**: …...
前端开发知识(一)-html
1.前端开发需掌握的内容: 2.前端开发的三剑客:html、css、javascript Vue可以简化JavaScpript流程。 Element(饿了么开发的) :前端组件库。 Ngix:前端服务器。 3.前端开发工具:vscode 1)按…...
身份证如何查验真伪?C#身份证二要素、三要素接口集成
身份证不仅是我们的身份证明,更是社会生活中的“通行证”,现在人们的衣食住行都离不开身份证。但对于提供服务的平台而言,如何对用户提供的身份信息进行真伪核验便成为了一大难题。别担心,今天小编为服务平台带来了身份证二要素、…...
C++ | Leetcode C++题解之第290题单词规律
题目: 题解: class Solution { public:bool wordPattern(string pattern, string str) {unordered_map<string, char> str2ch;unordered_map<char, string> ch2str;int m str.length();int i 0;for (auto ch : pattern) {if (i > m) {…...
Pytorch使用教学7-张量的广播
PyTorch中的张量具有和NumPy相同的广播特性,允许不同形状的张量之间进行计算。 广播的实质特性,其实是低维向量映射到高维之后,相同位置再进行相加。我们重点要学会的就是低维向量如何向高维向量进行映射。 相同形状的张量计算 虽然我们觉…...
生成式AI:对话系统(Chat)与自主代理(Agent)的和谐共舞
生成式AI:对话与行动的和谐共舞 我们正站在一个令人激动的时代门槛上——生成式AI技术飞速发展,带来了无限的可能性。一个关键问题浮现:AI的未来是对话系统(Chat)的天下,还是自主代理(Agent&am…...
唯众物联网(IOT)全功能综合实训教学解决方案
一、引言 在信息技术日新月异的今天,物联网(IoT)作为推动数字化转型的关键力量,其触角已延伸至我们生活的方方面面,深刻地重塑了工作模式、生活习惯乃至社会结构的每一个角落。面对这一前所未有的变革浪潮,…...
24证券从业考试报名『个人信息表』填写模板❗
24证券从业考试报名『个人信息表』填写模板❗ 1️⃣居住城市、通讯地址:写自己现居住的地址就可以。 2️⃣学历:需要注意的是学历填写的是考生已经取得的学历,在校大学生已经不具有报名资格,选择大专以上,或者是高中学…...
【大模型RAG】拍照搜题技术架构速览:三层管道、两级检索、兜底大模型
摘要 拍照搜题系统采用“三层管道(多模态 OCR → 语义检索 → 答案渲染)、两级检索(倒排 BM25 向量 HNSW)并以大语言模型兜底”的整体框架: 多模态 OCR 层 将题目图片经过超分、去噪、倾斜校正后,分别用…...
盘古信息PCB行业解决方案:以全域场景重构,激活智造新未来
一、破局:PCB行业的时代之问 在数字经济蓬勃发展的浪潮中,PCB(印制电路板)作为 “电子产品之母”,其重要性愈发凸显。随着 5G、人工智能等新兴技术的加速渗透,PCB行业面临着前所未有的挑战与机遇。产品迭代…...
大型活动交通拥堵治理的视觉算法应用
大型活动下智慧交通的视觉分析应用 一、背景与挑战 大型活动(如演唱会、马拉松赛事、高考中考等)期间,城市交通面临瞬时人流车流激增、传统摄像头模糊、交通拥堵识别滞后等问题。以演唱会为例,暖城商圈曾因观众集中离场导致周边…...
大语言模型如何处理长文本?常用文本分割技术详解
为什么需要文本分割? 引言:为什么需要文本分割?一、基础文本分割方法1. 按段落分割(Paragraph Splitting)2. 按句子分割(Sentence Splitting)二、高级文本分割策略3. 重叠分割(Sliding Window)4. 递归分割(Recursive Splitting)三、生产级工具推荐5. 使用LangChain的…...
剑指offer20_链表中环的入口节点
链表中环的入口节点 给定一个链表,若其中包含环,则输出环的入口节点。 若其中不包含环,则输出null。 数据范围 节点 val 值取值范围 [ 1 , 1000 ] [1,1000] [1,1000]。 节点 val 值各不相同。 链表长度 [ 0 , 500 ] [0,500] [0,500]。 …...
Qwen3-Embedding-0.6B深度解析:多语言语义检索的轻量级利器
第一章 引言:语义表示的新时代挑战与Qwen3的破局之路 1.1 文本嵌入的核心价值与技术演进 在人工智能领域,文本嵌入技术如同连接自然语言与机器理解的“神经突触”——它将人类语言转化为计算机可计算的语义向量,支撑着搜索引擎、推荐系统、…...
屋顶变身“发电站” ,中天合创屋面分布式光伏发电项目顺利并网!
5月28日,中天合创屋面分布式光伏发电项目顺利并网发电,该项目位于内蒙古自治区鄂尔多斯市乌审旗,项目利用中天合创聚乙烯、聚丙烯仓库屋面作为场地建设光伏电站,总装机容量为9.96MWp。 项目投运后,每年可节约标煤3670…...
【C语言练习】080. 使用C语言实现简单的数据库操作
080. 使用C语言实现简单的数据库操作 080. 使用C语言实现简单的数据库操作使用原生APIODBC接口第三方库ORM框架文件模拟1. 安装SQLite2. 示例代码:使用SQLite创建数据库、表和插入数据3. 编译和运行4. 示例运行输出:5. 注意事项6. 总结080. 使用C语言实现简单的数据库操作 在…...
Java 二维码
Java 二维码 **技术:**谷歌 ZXing 实现 首先添加依赖 <!-- 二维码依赖 --><dependency><groupId>com.google.zxing</groupId><artifactId>core</artifactId><version>3.5.1</version></dependency><de…...
Linux离线(zip方式)安装docker
目录 基础信息操作系统信息docker信息 安装实例安装步骤示例 遇到的问题问题1:修改默认工作路径启动失败问题2 找不到对应组 基础信息 操作系统信息 OS版本:CentOS 7 64位 内核版本:3.10.0 相关命令: uname -rcat /etc/os-rele…...
