当前位置: 首页 > news >正文

【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-filecluster-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开发&#xff0c;前后端不分离时的页面渲染 SpringBoot整合enjoy模板引擎步骤&#xff1a; 1.将页面保存在templates目录下 2.添加enjoy的坐标 <dependency> <groupId>com.jfinal</groupId> <artifactId>enjoy</artifactId&g…...

【学习笔记】如何训练大模型

如何在许多 GPU 上训练真正的大型模型&#xff1f; 单个 GPU 工作线程的内存有限&#xff0c;并且许多大型模型的大小已经超出了单个 GPU 的范围。有几种并行范式可以跨多个 GPU 进行模型训练&#xff0c;还可以使用各种模型架构和内存节省设计来帮助训练超大型神经网络。 并…...

高可用集群KEEPALIVED

一、集群相关概念简述 HA是High Available缩写&#xff0c;是双机集群系统简称&#xff0c;指高可用性集群&#xff0c;是保证业务连续性的有效解决方案&#xff0c;一般有两个或两个以上的节点&#xff0c;且分为活动节点及备用节点。 1、集群的分类 LB&#xff1a;负载均衡…...

Linux shell编程学习笔记69: curl 命令行网络数据传输工具 选项数量雷人(中)

0 前言 curl是Linux中的一款综合性网络传输工具&#xff0c;既可以上传也可以下载&#xff0c;支持HTTP、HTTPS、FTP等30余种常见协‍议。 该命令选项超多&#xff0c;在学习笔记68中&#xff0c;我们列举了该命令的部分实例&#xff0c;今天继续通过实例来研究curl命令的功能…...

怎么在网站底部添加站点地图?

在优化网站 SEO 时&#xff0c;站点地图&#xff08;Sitemap&#xff09;是一个非常重要的工具。它帮助搜索引擎更好地理解和抓取您的网站内容。幸运的是&#xff0c;从 WordPress 5.5 开始&#xff0c;WordPress 自带了站点地图生成功能&#xff0c;无需额外插件。下面将介绍如…...

bash和sh的区别

‌Bash和‌sh的主要区别在于它们的交互性、兼容性、默认shell以及脚本执行方式。 首先&#xff0c;Bash提供了更丰富的交互功能&#xff0c;使得它在终端中的使用更加舒适和方便。相比之下&#xff0c;sh由于其最小化的功能集&#xff0c;提供了更广泛的兼容性。然而&#xff…...

基于LSTM的锂电池剩余寿命预测 [电池容量提取+锂电池寿命预测] Matlab代码

基于LSTM的锂电池剩余寿命预测 [电池容量提取锂电池寿命预测] Matlab代码 无需更改代码&#xff0c;双击main直接运行&#xff01;&#xff01;&#xff01; 1、内含“电池容量提取”和“锂电池寿命预测”两个部分完整代码和NASA的电池数据 2、提取NASA数据集的电池容量&am…...

PHP项目任务系统小程序源码

&#x1f680;解锁高效新境界&#xff01;我的项目任务系统大揭秘&#x1f50d; &#x1f31f; 段落一&#xff1a;引言 - 为什么需要项目任务系统&#xff1f; Hey小伙伴们&#xff01;你是否曾为了杂乱的待办事项焦头烂额&#xff1f;&#x1f92f; 或是项目截止日逼近&…...

乡村振兴旅游休闲景观解决方案

乡村振兴旅游休闲景观解决方案摘要 2. 规划方案概览 规划核心&#xff1a;PPT展示了乡村振兴建设规划的核心区平面图及鸟瞰图&#xff0c;涵盖景观小品、设施农业、自行车道、新社区等设计元素。 规划策略&#xff1a;方案注重打造大开大合的空间感受&#xff0c;特色农产大观…...

【大数据】重塑时代的核心技术及其发展历程

&#x1f407;明明跟你说过&#xff1a;个人主页 &#x1f3c5;个人专栏&#xff1a;《大数据前沿&#xff1a;技术与应用并进》&#x1f3c5; &#x1f516;行路有良友&#xff0c;便是天堂&#x1f516; 目录 一、引言 1、什么是大数据 2、大数据技术诞生的背景 二、大…...

基于python的小区监控图像拼接系统设计与实现

博主介绍&#xff1a; 大家好&#xff0c;本人精通Java、Python、C#、C、C编程语言&#xff0c;同时也熟练掌握微信小程序、Php和Android等技术&#xff0c;能够为大家提供全方位的技术支持和交流。 我有丰富的成品Java、Python、C#毕设项目经验&#xff0c;能够为学生提供各类…...

在HFSS中对曲线等结构进行分割(Split)

在HFSS中对曲线进行分割 我们往往需要把DXF等其他类型文件导入HFSS进行分析&#xff0c;但是有时需要对某一个曲线单独进行分割成两段修改。 如果是使用HFSS绘制的曲线&#xff0c;我们修改起来非常方便&#xff0c;修改参数即可。但是如果是导入的曲线&#xff0c;则需要使用…...

高等数学精解【8】

文章目录 直线与二元一次方程平行垂直题目点到直线距离直线束概述直线束的详细说明一、定义二、计算 三、例子例子1&#xff1a;中心直线束例子2&#xff1a;平行直线束 四、例题 参考文献 直线与二元一次方程 平行 两直线平等的条件是它们的斜率相同。 L 1 : A 1 x B 1 y …...

山石网科---WAF---巨细

文章目录 前言一、pandas是什么&#xff1f;二、使用步骤 1.引入库2.读入数据总结 前言 今天被安排协助一线上架一台WAF&#xff0c;在这里重点总结一下WAF的内容 一.WAF部署 串联透明模式 串联模式特点&#xff1a; 二层透明接入&#xff0c;对客户网络影响小站点和webserve…...

【C++】6.类和对象(4)

文章目录 5.赋值运算符重载5.1 运算符重载5.2 赋值运算符重载5.3 前置和后置重载5.4 日期类的实现 6.取地址运算符重载6.1 const成员函数6.2 取地址运算符重载 5.赋值运算符重载 5.1 运算符重载 当运算符被用于类类型的对象时&#xff0c;C语言允许我们通过运算符重载的形式指…...

【5.2 python中的列表】

python中的列表 Python中的列表&#xff08;List&#xff09;是一种非常灵活且强大的数据结构&#xff0c;用于存储一系列的元素。列表是可变的&#xff0c;意味着你可以添加、删除或修改列表中的元素。列表中的元素可以是不同类型的数据&#xff0c;包括整数、浮点数、字符串、…...

opencv-特征检测

1&#xff0c;Harris角点检测 如果粉色窗口向四周移动&#xff0c;窗口内的像素没有变化则认定为平坦区域&#xff0c;如果窗口向上移动无明显变化&#xff0c;而左右移动有变化则认定为边缘&#xff0c;如果窗口向任意方向移动均有明显变化则为角点&#xff0c;如下图 dst不是…...

FastAPI 教程:从入门到实践

FastAPI 是一个现代、快速&#xff08;高性能&#xff09;的 Web 框架&#xff0c;用于构建 API&#xff0c;支持 Python 3.6。它基于标准 Python 类型提示&#xff0c;易于学习且功能强大。以下是一个完整的 FastAPI 入门教程&#xff0c;涵盖从环境搭建到创建并运行一个简单的…...

多模态商品数据接口:融合图像、语音与文字的下一代商品详情体验

一、多模态商品数据接口的技术架构 &#xff08;一&#xff09;多模态数据融合引擎 跨模态语义对齐 通过Transformer架构实现图像、语音、文字的语义关联。例如&#xff0c;当用户上传一张“蓝色连衣裙”的图片时&#xff0c;接口可自动提取图像中的颜色&#xff08;RGB值&…...

基于Docker Compose部署Java微服务项目

一. 创建根项目 根项目&#xff08;父项目&#xff09;主要用于依赖管理 一些需要注意的点&#xff1a; 打包方式需要为 pom<modules>里需要注册子模块不要引入maven的打包插件&#xff0c;否则打包时会出问题 <?xml version"1.0" encoding"UTF-8…...

vue3 定时器-定义全局方法 vue+ts

1.创建ts文件 路径&#xff1a;src/utils/timer.ts 完整代码&#xff1a; import { onUnmounted } from vuetype TimerCallback (...args: any[]) > voidexport function useGlobalTimer() {const timers: Map<number, NodeJS.Timeout> new Map()// 创建定时器con…...

06 Deep learning神经网络编程基础 激活函数 --吴恩达

深度学习激活函数详解 一、核心作用 引入非线性:使神经网络可学习复杂模式控制输出范围:如Sigmoid将输出限制在(0,1)梯度传递:影响反向传播的稳定性二、常见类型及数学表达 Sigmoid σ ( x ) = 1 1 +...

return this;返回的是谁

一个审批系统的示例来演示责任链模式的实现。假设公司需要处理不同金额的采购申请&#xff0c;不同级别的经理有不同的审批权限&#xff1a; // 抽象处理者&#xff1a;审批者 abstract class Approver {protected Approver successor; // 下一个处理者// 设置下一个处理者pub…...

MFC 抛体运动模拟:常见问题解决与界面美化

在 MFC 中开发抛体运动模拟程序时,我们常遇到 轨迹残留、无效刷新、视觉单调、物理逻辑瑕疵 等问题。本文将针对这些痛点,详细解析原因并提供解决方案,同时兼顾界面美化,让模拟效果更专业、更高效。 问题一:历史轨迹与小球残影残留 现象 小球运动后,历史位置的 “残影”…...

深度学习之模型压缩三驾马车:模型剪枝、模型量化、知识蒸馏

一、引言 在深度学习中&#xff0c;我们训练出的神经网络往往非常庞大&#xff08;比如像 ResNet、YOLOv8、Vision Transformer&#xff09;&#xff0c;虽然精度很高&#xff0c;但“太重”了&#xff0c;运行起来很慢&#xff0c;占用内存大&#xff0c;不适合部署到手机、摄…...

Xela矩阵三轴触觉传感器的工作原理解析与应用场景

Xela矩阵三轴触觉传感器通过先进技术模拟人类触觉感知&#xff0c;帮助设备实现精确的力测量与位移监测。其核心功能基于磁性三维力测量与空间位移测量&#xff0c;能够捕捉多维触觉信息。该传感器的设计不仅提升了触觉感知的精度&#xff0c;还为机器人、医疗设备和制造业的智…...

保姆级【快数学会Android端“动画“】+ 实现补间动画和逐帧动画!!!

目录 补间动画 1.创建资源文件夹 2.设置文件夹类型 3.创建.xml文件 4.样式设计 5.动画设置 6.动画的实现 内容拓展 7.在原基础上继续添加.xml文件 8.xml代码编写 (1)rotate_anim (2)scale_anim (3)translate_anim 9.MainActivity.java代码汇总 10.效果展示 逐帧…...