【Redis进阶】Redis集群
目录
Redis集群的诞生
单节点Redis的局限性
1.存储容量限制
2.性能瓶颈
3.单点故障
4.扩展性能差
分布式系统发展的需要
1.海量数据处理
2.高性能要求
3.弹性扩展能力
Redis集群(cluster)
如图所示案例
Redis集群设计
什么是数据分片(data sharding)
数据访问如何定位到具体的节点
Redis集群工作原理
Redis集群搭建
Redis集群的优缺点
优点
缺点
Redis集群的常见问题及优化
Redis集群的诞生
在前面文章,我们介绍过Redis的主从复制的诞生是为了实现读写分离,提高数据的安全性;
哨兵机制的诞生是为了主节点宕机,可以自动选择一个从节点替换掉主节点,避免了人工干预。
虽然主从复制+哨兵模式采用了多节点,但是它们存在的目的主要是解决容灾问题,并不是性能问题。
随着Redis在各类高并发,高性能系统中的广泛应用,单节点Redis的局限性逐渐显现出来,而Redis集群正式为了解决这些局限性而设计的。
单节点Redis的局限性
1.存储容量限制
- Redis 是基于内存的存储系统,因此其存储容量受限于单台机器的内存大小。对于一些需要存储海量数据的应用,单节点 Redis 的内存容量很快就会成为瓶颈。
2.性能瓶颈
- 随着系统规模的扩大,单节点 Redis 的 CPU 和网络带宽可能无法满足不断增加的读写请求。尤其在高并发场景下,单节点 Redis 容易出现性能瓶颈,影响整个系统的响应速度。
3.单点故障
- 虽然 Redis 提供了主从复制机制,但在单节点模式下,如果主节点出现故障,系统的可用性就会受到影响。即使通过 Redis Sentinel 可以实现自动故障转移,但在大规模应用场景中,仍然需要更高的可靠性和容错能力。
4.扩展性能差
- 在单节点模式下,Redis 的扩展性有限。当需要扩展存储容量或提升性能时,通常只能通过增加单台机器的硬件资源来实现,而无法通过简单地增加节点来水平扩展。
分布式系统发展的需要
随着互联网应用的迅猛发展,越来越多的系统需要处理海量数据和高并发请求。这些系统的特点包括:
1.海量数据处理
- 现代应用(如社交网络、电商平台、物联网等)通常需要处理和存储庞大的数据量,这些数据往往需要在内存中进行快速读写操作。
2.高性能要求
- 许多系统需要提供 7x24 小时不间断的服务,容忍节点故障成为了高可用性的基本要求。
3.弹性扩展能力
- 随着业务的发展,系统的负载可能会急剧增加。因此,系统需要能够快速、无缝地扩展以应对流量高峰。
正是在这样的大数据高并发的需求之下,Redis 集群方案应运而生。redis集群是对redis的水平扩容,即启动m个redis节点,将整个数据分布存储在这个m个节点中,每个节点存储总数据的1/m。
Redis集群(cluster)
如图所示案例

如图所示:3主3从组成的集群,每台master承担三分之一的请求和数据。集群中节点之间使用gossip协议进行通信,实现了去中心化。
Redis集群设计
提到集群,必然离不开数据分片。
什么是数据分片(data sharding)
数据分片(Data Sharding)是一种将数据集分割成更小的部分(称为"片"或"分片")并分布到多个存储单元(如数据库或服务器)上的技术。每个分片只存储数据集的一部分,从而使得系统能够水平扩展,处理更大规模的数据量和更高的并发请求。
Redis Cluster使用数据分片实现key的存储分布
Redis Cluster将集群划分为16384个槽位,数据库中所有的key进行hash计算后,都会落到16384个槽位中的其中一个槽位。那么key是如何定位到哪个槽位的呢,可以通过公式进行计算:CRC16(key)%16384,得到的值就是槽位;16384个槽位全部分配给cluster中的节点,每个节点维护自己的槽位,同时每个节点也会存储其他节点维护的槽位信息。
数据访问如何定位到具体的节点

如上图所示
- 1.如果客户端发送过来的key刚好在节点1所维护的范围之内,直接返回结果
- 2.如果客户端发送过来的key不在节点1所维护的范围之内,节点1会返回moved命令,告诉客户端所请求的key在节点2所维护的槽内,客户端收到命令之后,向正确的节点重新发送获取命令,拿到返回结果。
Redis集群工作原理
1.数据分片
当客户端发送写入请求时,Redis 集群使用 CRC16 算法对键进行哈希运算,得到一个哈希值,然后对 16384 取模,确定该键对应的槽。集群中的某个节点负责这个槽的所有键。
2.请求路由
客户端可以直接连接到集群中的任意节点。当请求的数据不在当前节点上时,该节点会返回一个 MOVED 响应,指引客户端向正确的节点发送请求。
3.故障检测与自动故障转移
Redis 集群中的每个节点都会通过 Gossip 协议交换彼此的状态。如果一个主节点被大多数主节点判定为不可用(称为主观下线,SDOWN),集群会尝试将其从节点提升为主节点,并接管它负责的槽(称为客观下线,ODOWN)。
4.数据一致性
Redis 集群采用异步复制机制,从节点异步地复制主节点的数据。如果主节点故障,部分数据可能丢失,尽管如此,Redis 集群仍然保证大多数情况下的高可用性和数据完整性。
Redis集群搭建
要搭建 Redis 集群,通常需要至少 6 个 Redis 实例(3 个主节点,3 个从节点)。以下是搭建 Redis 集群的基本步骤:
1.准备Redis实例
- 安装 Redis,并配置多个实例,每个实例配置不同的端口和
cluster-enabled yes选项。
2.配置节点
- 每个 Redis 实例的配置文件(如
redis.conf)中需要设置cluster-enabled yes,并指定cluster-config-file和cluster-node-timeout。
3.启动Redis实例
- 启动所有 Redis 实例,使它们处于独立运行状态。
4.创建集群
- 使用 Redis 自带的
redis-cli工具执行redis-cli --cluster create命令,将多个 Redis 实例组成一个集群。 - 在执行此命令时,需要指定主从节点,并划分 16384 个槽给各个主节点。
5.检查集群状态
- 使用
redis-cli --cluster check命令检查集群状态,确保所有节点正确配置并互相连接。
Redis集群的优缺点
优点
-
可扩展性:通过数据分片,Redis 集群能够水平扩展,将数据分布在多个节点上,从而扩展存储容量和吞吐量。
-
高可用性:通过主从复制和自动故障转移,Redis 集群能够在主节点故障时自动恢复,并继续提供服务。
-
无中心架构:Redis 集群采用无中心架构,避免了单点故障,使得整个集群更加稳定和健壮。
缺点
-
复杂性增加:与单节点 Redis 相比,Redis 集群的部署和管理更加复杂,特别是在处理节点故障和数据恢复时。
-
数据一致性问题:由于采用异步复制,Redis 集群在主节点故障时可能会丢失部分数据。
-
槽迁移:在动态扩展或缩减集群时,槽的迁移可能会导致暂时性的服务中断。
Redis集群的常见问题及优化
1.避免网络分区
- 网络分区可能导致集群的部分节点不可用。可以通过设置合理的超时时间和定期的节点检查来减少网络分区的影响。
2.优化读写性能
- 为了提高读写性能,可以通过增加从节点数量和使用客户端的智能路由机制来优化读写操作的分布
3.数据重分片
- 在扩展或缩减集群时,需要对槽进行重新分配。为了减少对服务的影响,可以使用 Redis 提供的工具
redis-trib或者redis-cli进行平滑的数据迁移。
4.监控与告警
- 使用监控工具(如 Redis Sentinel、Prometheus 等)实时监控 Redis 集群的状态,并配置告警策略,及时处理集群中的异常情况。
Redis 集群通过数据分片、主从复制和无中心架构,提供了一种高可用、可扩展的分布式键值存储解决方案。尽管它的部署和管理较为复杂,但对于大规模、高可用性需求的应用场景,Redis 集群是一个强大的工具。通过合理的配置、优化和监控,Redis 集群能够为分布式应用提供强大的数据支持和高性能的存储服务。
相关文章:
【Redis进阶】Redis集群
目录 Redis集群的诞生 单节点Redis的局限性 1.存储容量限制 2.性能瓶颈 3.单点故障 4.扩展性能差 分布式系统发展的需要 1.海量数据处理 2.高性能要求 3.弹性扩展能力 Redis集群(cluster) 如图所示案例 Redis集群设计 什么是数据分片&…...
JVM运行时数据区之虚拟机栈
【1】概述 Java虚拟机栈(Java Virtual Machine Stack),早期也叫Java栈。每个线程在创建时都会创建一个虚拟机栈,其内部保存一个个的栈帧(Stack Frame),对应着一次次的Java方法调用。 栈是运行…...
Python 机器学习求解 PDE 学习项目 基础知识(4)PyTorch 库函数使用详细案例
PyTorch 库函数使用详细案例 前言 在深度学习中,PyTorch 是一个广泛使用的开源机器学习库。它提供了强大的功能,用于构建、训练和评估深度学习模型。本文档将详细介绍如何使用以下 PyTorch 相关库函数,并提供相应的案例示例: to…...
SpringBoot-enjoy模板引擎
主要用于Web开发,前后端不分离时的页面渲染 SpringBoot整合enjoy模板引擎步骤: 1.将页面保存在templates目录下 2.添加enjoy的坐标 <dependency> <groupId>com.jfinal</groupId> <artifactId>enjoy</artifactId&g…...
【学习笔记】如何训练大模型
如何在许多 GPU 上训练真正的大型模型? 单个 GPU 工作线程的内存有限,并且许多大型模型的大小已经超出了单个 GPU 的范围。有几种并行范式可以跨多个 GPU 进行模型训练,还可以使用各种模型架构和内存节省设计来帮助训练超大型神经网络。 并…...
高可用集群KEEPALIVED
一、集群相关概念简述 HA是High Available缩写,是双机集群系统简称,指高可用性集群,是保证业务连续性的有效解决方案,一般有两个或两个以上的节点,且分为活动节点及备用节点。 1、集群的分类 LB:负载均衡…...
Linux shell编程学习笔记69: curl 命令行网络数据传输工具 选项数量雷人(中)
0 前言 curl是Linux中的一款综合性网络传输工具,既可以上传也可以下载,支持HTTP、HTTPS、FTP等30余种常见协议。 该命令选项超多,在学习笔记68中,我们列举了该命令的部分实例,今天继续通过实例来研究curl命令的功能…...
怎么在网站底部添加站点地图?
在优化网站 SEO 时,站点地图(Sitemap)是一个非常重要的工具。它帮助搜索引擎更好地理解和抓取您的网站内容。幸运的是,从 WordPress 5.5 开始,WordPress 自带了站点地图生成功能,无需额外插件。下面将介绍如…...
bash和sh的区别
Bash和sh的主要区别在于它们的交互性、兼容性、默认shell以及脚本执行方式。 首先,Bash提供了更丰富的交互功能,使得它在终端中的使用更加舒适和方便。相比之下,sh由于其最小化的功能集,提供了更广泛的兼容性。然而ÿ…...
基于LSTM的锂电池剩余寿命预测 [电池容量提取+锂电池寿命预测] Matlab代码
基于LSTM的锂电池剩余寿命预测 [电池容量提取锂电池寿命预测] Matlab代码 无需更改代码,双击main直接运行!!! 1、内含“电池容量提取”和“锂电池寿命预测”两个部分完整代码和NASA的电池数据 2、提取NASA数据集的电池容量&am…...
PHP项目任务系统小程序源码
🚀解锁高效新境界!我的项目任务系统大揭秘🔍 🌟 段落一:引言 - 为什么需要项目任务系统? Hey小伙伴们!你是否曾为了杂乱的待办事项焦头烂额?🤯 或是项目截止日逼近&…...
乡村振兴旅游休闲景观解决方案
乡村振兴旅游休闲景观解决方案摘要 2. 规划方案概览 规划核心:PPT展示了乡村振兴建设规划的核心区平面图及鸟瞰图,涵盖景观小品、设施农业、自行车道、新社区等设计元素。 规划策略:方案注重打造大开大合的空间感受,特色农产大观…...
【大数据】重塑时代的核心技术及其发展历程
🐇明明跟你说过:个人主页 🏅个人专栏:《大数据前沿:技术与应用并进》🏅 🔖行路有良友,便是天堂🔖 目录 一、引言 1、什么是大数据 2、大数据技术诞生的背景 二、大…...
基于python的小区监控图像拼接系统设计与实现
博主介绍: 大家好,本人精通Java、Python、C#、C、C编程语言,同时也熟练掌握微信小程序、Php和Android等技术,能够为大家提供全方位的技术支持和交流。 我有丰富的成品Java、Python、C#毕设项目经验,能够为学生提供各类…...
在HFSS中对曲线等结构进行分割(Split)
在HFSS中对曲线进行分割 我们往往需要把DXF等其他类型文件导入HFSS进行分析,但是有时需要对某一个曲线单独进行分割成两段修改。 如果是使用HFSS绘制的曲线,我们修改起来非常方便,修改参数即可。但是如果是导入的曲线,则需要使用…...
高等数学精解【8】
文章目录 直线与二元一次方程平行垂直题目点到直线距离直线束概述直线束的详细说明一、定义二、计算 三、例子例子1:中心直线束例子2:平行直线束 四、例题 参考文献 直线与二元一次方程 平行 两直线平等的条件是它们的斜率相同。 L 1 : A 1 x B 1 y …...
山石网科---WAF---巨细
文章目录 前言一、pandas是什么?二、使用步骤 1.引入库2.读入数据总结 前言 今天被安排协助一线上架一台WAF,在这里重点总结一下WAF的内容 一.WAF部署 串联透明模式 串联模式特点: 二层透明接入,对客户网络影响小站点和webserve…...
【C++】6.类和对象(4)
文章目录 5.赋值运算符重载5.1 运算符重载5.2 赋值运算符重载5.3 前置和后置重载5.4 日期类的实现 6.取地址运算符重载6.1 const成员函数6.2 取地址运算符重载 5.赋值运算符重载 5.1 运算符重载 当运算符被用于类类型的对象时,C语言允许我们通过运算符重载的形式指…...
【5.2 python中的列表】
python中的列表 Python中的列表(List)是一种非常灵活且强大的数据结构,用于存储一系列的元素。列表是可变的,意味着你可以添加、删除或修改列表中的元素。列表中的元素可以是不同类型的数据,包括整数、浮点数、字符串、…...
opencv-特征检测
1,Harris角点检测 如果粉色窗口向四周移动,窗口内的像素没有变化则认定为平坦区域,如果窗口向上移动无明显变化,而左右移动有变化则认定为边缘,如果窗口向任意方向移动均有明显变化则为角点,如下图 dst不是…...
后进先出(LIFO)详解
LIFO 是 Last In, First Out 的缩写,中文译为后进先出。这是一种数据结构的工作原则,类似于一摞盘子或一叠书本: 最后放进去的元素最先出来 -想象往筒状容器里放盘子: (1)你放进的最后一个盘子(…...
使用docker在3台服务器上搭建基于redis 6.x的一主两从三台均是哨兵模式
一、环境及版本说明 如果服务器已经安装了docker,则忽略此步骤,如果没有安装,则可以按照一下方式安装: 1. 在线安装(有互联网环境): 请看我这篇文章 传送阵>> 点我查看 2. 离线安装(内网环境):请看我这篇文章 传送阵>> 点我查看 说明:假设每台服务器已…...
基于FPGA的PID算法学习———实现PID比例控制算法
基于FPGA的PID算法学习 前言一、PID算法分析二、PID仿真分析1. PID代码2.PI代码3.P代码4.顶层5.测试文件6.仿真波形 总结 前言 学习内容:参考网站: PID算法控制 PID即:Proportional(比例)、Integral(积分&…...
生成 Git SSH 证书
🔑 1. 生成 SSH 密钥对 在终端(Windows 使用 Git Bash,Mac/Linux 使用 Terminal)执行命令: ssh-keygen -t rsa -b 4096 -C "your_emailexample.com" 参数说明: -t rsa&#x…...
JVM暂停(Stop-The-World,STW)的原因分类及对应排查方案
JVM暂停(Stop-The-World,STW)的完整原因分类及对应排查方案,结合JVM运行机制和常见故障场景整理而成: 一、GC相关暂停 1. 安全点(Safepoint)阻塞 现象:JVM暂停但无GC日志,日志显示No GCs detected。原因:JVM等待所有线程进入安全点(如…...
力扣-35.搜索插入位置
题目描述 给定一个排序数组和一个目标值,在数组中找到目标值,并返回其索引。如果目标值不存在于数组中,返回它将会被按顺序插入的位置。 请必须使用时间复杂度为 O(log n) 的算法。 class Solution {public int searchInsert(int[] nums, …...
【VLNs篇】07:NavRL—在动态环境中学习安全飞行
项目内容论文标题NavRL: 在动态环境中学习安全飞行 (NavRL: Learning Safe Flight in Dynamic Environments)核心问题解决无人机在包含静态和动态障碍物的复杂环境中进行安全、高效自主导航的挑战,克服传统方法和现有强化学习方法的局限性。核心算法基于近端策略优化…...
华为OD机试-最短木板长度-二分法(A卷,100分)
此题是一个最大化最小值的典型例题, 因为搜索范围是有界的,上界最大木板长度补充的全部木料长度,下界最小木板长度; 即left0,right10^6; 我们可以设置一个候选值x(mid),将木板的长度全部都补充到x,如果成功…...
uniapp 实现腾讯云IM群文件上传下载功能
UniApp 集成腾讯云IM实现群文件上传下载功能全攻略 一、功能背景与技术选型 在团队协作场景中,群文件共享是核心需求之一。本文将介绍如何基于腾讯云IMCOS,在uniapp中实现: 群内文件上传/下载文件元数据管理下载进度追踪跨平台文件预览 二…...
五子棋测试用例
一.项目背景 1.1 项目简介 传统棋类文化的推广 五子棋是一种古老的棋类游戏,有着深厚的文化底蕴。通过将五子棋制作成网页游戏,可以让更多的人了解和接触到这一传统棋类文化。无论是国内还是国外的玩家,都可以通过网页五子棋感受到东方棋类…...
