池州做网站/自己的网站

池州做网站,自己的网站,免费贴图素材,如何做网站好看文章中相关知识点在往期已经更新过了,如果有友友不理解可翻看往期内容 出现脑裂问题怎么保证集群还是高可用的 什么是脑裂问题 脑裂说的就是当我们的主节点没有挂,但是因为网络延迟较大,然后和主节点相连的哨兵通信较差,之后主…

文章中相关知识点在往期已经更新过了,如果有友友不理解可翻看往期内容

出现脑裂问题怎么保证集群还是高可用的

什么是脑裂问题

脑裂说的就是当我们的主节点没有挂,但是因为网络延迟较大,然后和主节点相连的哨兵通信较差,之后主从之间的同步就会受影响,主节点和哨兵之间的信号也不好,但是客户端和主节点之间还能进行通信,此时向主节点更新了一条数据,而由于网络问题,从节点未能同步,且由于哨兵集群和主节点之间的通信较差每次ping都收到主节点的恢复,那么哨兵集群就会判断主节点从主观下线到了客观下线(超过了设置的客观下线的数量),那么此时哨兵就会认为主节点挂了,此时会选取一个哨兵作为主节点,然后强行修改原来主节点的配置将其设置为该slave节点的从节点(然后向新的主节点发起主从同步的时候就会进行全量同步,因此原来主节点中更新的那个消息就会彻底丢失),但是此时的问题就是新的从节点并没有原来更新的那条数据的信息,这样就造成了数据的不一致。这就是脑裂问题

解决的核心思路就是

由于是因为主节点能处理客服端的更新操作和,网络延迟导致主从不一致,然后又由哨兵选取从节点变更为主节点导致的数据丢失,那么我们就可以采取这样的操作,即当发生这种网络延迟问题时,我们就拒绝客服端发过来的请求,这样就保证网络延迟期间主从的一致性,此时就算哨兵将从节点设置为新的主节点也没关系,因为数据被没有被更新,从节点中还是有所有数据

具体解决

具体解决就可以在配置文件中进行配置主节点发现从节点下线或者通信超时的总数量小于阈值

当主节点发现从节点下线或者通信超时的总数量小于阈值时,那么禁止主节点进行写数据,直接把错误返回给客户端。

在 Redis 的配置文件中有两个参数我们可以设置:

  • min-slaves-to-write x,与主节点能连接的同的从节点个数只有超过x时才能进行写操作,否之拒绝写操作
  • min-slaves-max-lag x,主从数据同步的延迟不能超过 x 秒,如果超过,主节点会禁止写数据。

我们可以把 min-slaves-to-write 和 min-slaves-max-lag 这两个配置项搭配起来使用,分别给它们设置一定的阈值,假设为 N 和 T。

这就表示这两个配置项组合后的要求是,主库连接的从库中至少有 N 个从库,和主库进行数据复制时的 ACK 消息延迟不能超过 T 秒,否则,主库就不会再接收客户端的写请求了。

大key、热key问题

大key

是什么?

Redis 中的 大 Key(Big Key) 是指存储的单个 Key 对应的 Value 过大(如字符串类型 Value 体积过大,或集合/列表/哈希等类型的元素数量过多)。这类 Key 会显著影响 Redis 的性能和稳定性,是实际应用中需要重点规避的问题。

大 Key 的典型场景

  1. 字符串类型
    • 存储大体积数据(如 1MB 以上的 JSON/二进制数据)。
    • 示例:缓存一个完整的商品详情页 HTML(可能达到几 MB)。
  1. 集合/列表/哈希类型
    • 元素数量过多(如哈希表存储百万级字段)。
    • 示例:用户粉丝列表存储了 100 万用户 ID。
  1. 流(Stream)类型
    • 消息队列堆积未及时消费,导致单个流包含大量消息。

大key的危害

  1. 影响redis的持久化
  2. 客户端超时阻塞:由于redis执行命令是单线程的,然后再操作大key时会比较耗时,那么就会阻塞redis,从客户端这边看,就是很久很久没响应
  3. 引发网络阻塞。每次获取大key产生的流量都较大,比如假设一个key的大小是1MB,此时每秒访问量为1000MB,那么每秒就会产生1000MB的流量,这对于普通的千兆服务器来说是灾难性的
  4. 阻塞工作线程。如果使用了del命令删除了大key,就会阻塞工作线程可以采用unclink来异步删除
  5. 存储倾斜(内存分布不均):集群再slot分片均匀的情况下,会产生数据和查询倾斜的情况,存储大key的Redis节点占用内存多

这里讲一下为什么会影响redis的持久化

主要还是redis的fork以及写时复制这个原因

首先关于aof的刷盘策略:
  • always:每次更新数据都进行刷盘,既每次都执行fsync()
  • everysecond:每秒刷盘:会创建一个异步任务来执行fsync()
  • no:数据到了aof buffer之后就不管了,由操作系统来进行控制刷盘,既永不执行fsync()函数

其实核心都是控制fsync()函数将内核缓冲区中的数据写到磁盘中

大key对于aof的持久化影响

如果设置的aof刷盘策略是Always策略,主线程再执行命令之后,会将数据写到AOF日志文件中,然后调用fsync()函数将内核缓冲区中的数据直接写到磁盘,等磁盘写操作完该函数才会返回,可以看到redis在这个过程中一直是阻塞等待的,即是单线程处理

所以在使用Always策略的时候,如果写入的是以一个大key,主线程执行fsync()函数的时候,阻塞时间会比较久,因为当写入的数据量很大的时候,数据会同步到磁盘这个过程很耗时

如果使用的是everysec或no的刷盘策略的话就持久化过程就不会影响主线程

大key对AOF重写和RDB的影响

1.对fork过程的影响

主要核心问题,AOF重写和RDB生成过程其实核心都是需要fork一个子进程,内核会将父进程中的页表也会复制一份给子进程,虽然子进程是独立运行的不影响主进程,但是在fork子进程的这个过程中是需要主进程参与的,

而大key说明所占空间比较大,也会导致页表所占空间增大,所以要是页表很大那么复制过程也是很耗时的,那么在fork时就会发生阻塞现象

2.因为在fork复制之后,主进程还会处理客户端的命令,如果客户端执行执行修改操作,那么主进程会进行写时复制操作(这个操作是主进程进行的),即将修改的数据拷贝一份到物理内存中,但如果修改的这个key就是大key那么这个复制过程也可能造成阻塞

    • 示例:对字符串类型的大 Value 按固定大小分块存储(如 big_data:part1, big_data:part2)。
  • 对于海量数据存储时,我们也可以通过上面两种方式先进行拆分key,拆分key之后redis会计算key的哈希值去找到对应的哈希巢slot,然后将这个大key就将其拆成不同的小key,对应不同的哈希槽slot,然后就可以分布到不同的节点,这样就可以有效解决数据倾斜问题

热key问题

是什么

Redis 中的 热 Key(Hot Key) 是指被高频访问的单个 Key,其请求量远高于其他 Key。这类 Key 会导致 Redis 实例或某个分片(Cluster 模式)的负载过高,引发性能瓶颈甚至服务崩溃。热 Key 问题需要结合业务场景和架构设计来预防和解决。

热 Key 的危害

  1. 单节点过载(多级缓存+对key拆分解决)
    • 在 Redis 集群模式下,热 Key 可能集中在某个分片(哈希槽),导致该节点 CPU/网络过载,而其他节点空闲。
    • 示例:某商品库存 Key 每秒接收 10 万次读取,远超单节点处理能力。
  1. 缓存雪崩风险(一致性要求高就直接加分布式锁,否之可以使用key的逻辑过期)
    • 若热 Key 突然失效(如过期或主动删除),大量请求穿透到数据库,可能引发级联故障。
  1. 性能抖动(参考大key问题)
    • 热 Key 的频繁访问可能导致 Redis 主线程阻塞(如大 Value 读取),影响其他请求的延迟

解决方案

主要:本地缓存+热key的冗余话存储+读写分离,如果读多那么可以考虑增加从节点的个数

2. 压缩数据
  • 对字符串类型的 Value 使用压缩算法(如 gzip、Snappy),读取时解压。
  • 需权衡 CPU 与内存的消耗(适合读少写多的场景)。
3. 设置过期时间
  • 对临时性大 Key 设置 TTL(如 EXPIRE),避免长期占用内存。

4. 异步删除
  • Redis 4.0+ 支持 UNLINK 命令替代 DEL,后台异步删除大 Key。
  • 配置 lazyfree-lazy-user-del yes,自动异步删除。
5. 限流与熔断
  • 客户端对大 Key 的访问做限流(如令牌桶算法),避免突发流量压垮服务。

1. 本地缓存(多级缓存)
  • 在应用层(客户端)对热 Key 添加本地缓存(如 Guava、Caffeine),减少对 Redis 的直接访问。
  • 适用场景:读多写少,允许短暂数据不一致(设置较短的本地 TTL)。
  • 示例:商品库存读取时,客户端缓存库存值 100ms,期间所有请求直接读本地缓存。
2. Key 分片(分散压力)
  • 将热 Key 拆分为多个子 Key,通过哈希或随机后缀分散到不同节点。
    • 示例:原 Key stock:item_123 拆分为 stock:item_123:1stock:item_123:2,客户端随机访问一个子 Key。
  • 注意:需确保数据一致性(如所有子 Key 同时更新)。
3. 读写分离
  • 对热 Key 启用读写分离,将读请求分发到从节点(需容忍主从同步延迟)。
  • 限制:Redis 集群模式下从节点不分担读请求(需 Proxy 或客户端分片)。
4. 缓存永不过期 + 异步更新
  • 对热 Key 不设置过期时间,通过后台任务定期更新缓存,避免缓存击穿。
  • 示例:商品库存每 10 秒异步更新一次,Key 永不过期。
5. 限流与熔断
  • 对热 Key 的访问进行限流(如令牌桶算法),超出阈值时熔断,返回默认值或降级数据。
  • 工具:使用 Sentinel、Hystrix 或 Resilience4j 实现。
6. 使用更高效的数据结构
  • 优化存储格式,减少单次访问的数据量。
    • 示例:用哈希表存储商品信息,按需获取字段(HGET 替代 GET),避免传输冗余数据。
7. Redis 集群扩容
  • 对热 Key 所在的分片进行垂直扩容(提升单节点配置)或水平扩容(增加分片数量,需迁移数据)。

这里讲一下key分片策略

方案核心思想
  1. 冗余存储
    将热 Key 复制多份,存储在不同的 Master 节点,例如 key:1(节点1)、key:2(节点2)。
  2. 请求分发
    客户端通过轮询或哈希算法,将请求均匀分发到不同副本,降低单个节点的压力。

适用场景

  • 读多写少:写入频率低,且容忍一定同步延迟(如缓存热点新闻)。
  • 高并发读:单 Key 的 QPS 远超单节点处理能力(如 10万+/秒)。
  • 集群模式:Redis 部署为 Cluster 模式,且 Master 节点数量充足。

优势
  1. 分散读压力
    读请求被均匀分发到多个节点,避免单节点过载。
  2. 高可用性
    冗余副本分散在不同节点,单个节点故障时,其他副本仍可提供服务(需配合故障转移)。
  3. 扩展性
    可通过增加副本数量(如 key:3key:4)应对更高并发。
潜在问题
1. 数据一致性
  • 写入成本高:每次更新需同步修改所有副本,否则会读到旧数据。
    • 示例:更新 key 时需同时更新 key:1key:2,若某次更新失败,会导致数据不一致。
  • 最终一致性:若副本间同步有延迟,客户端可能读到不同版本的数据。
2. 额外存储开销
  • 冗余副本占用更多内存,若 Key 的 Value 较大(如 1MB),存储成本显著增加。
3. 客户端复杂度
  • 客户端需维护所有副本的位置(如 key:1key:2),并实现负载均衡逻辑。
  • 若集群拓扑变化(如节点扩容/缩容),客户端需动态感知副本分布。
4. 写入放大效应
  • 对热 Key 的写入操作会放大 N 倍(N=副本数),可能引发性能问题。

优化方案
1. 异步复制(最终一致性)
  • 写入时仅更新主副本(如 key:1),通过后台任务异步同步到其他副本(如 key:2)。
  • 代价:读可能短暂不一致,适合对一致性要求不高的场景(如计数器缓存)。
2. 版本号控制
  • 为每个 Key 添加版本号(如 key:1:v100key:2:v100),客户端读取时校验版本号,若不一致则触发同步。
  • 示例
    • 写入时更新所有副本,并递增版本号。
    • 读取时优先访问一个副本,若发现版本号落后,触发同步。
3. 代理层分发
  • 使用中间件(如 Redis Proxy 或 Envoy)统一管理副本,客户端无感知。
    • 代理层维护副本列表,自动负载均衡读请求。
    • 写入时由代理层同步更新所有副本。
4. 结合读写分离
  • 主副本(如 key:1)处理写请求,其他副本(如 key:2key:3)作为只读副本。
  • 读请求分发到只读副本,写入仅需更新主副本,降低一致性复杂度。

与其他方案的对比

方案

优点

缺点

适用场景

冗余分片

分散读压力,高可用

数据一致性难,写入成本高

读多写少,容忍最终一致性

本地缓存

零网络开销,响应快

数据不一致,内存占用高

极高频读,允许短暂不一致

Key 分片(Hash)

天然分散压力,无需维护副本

拆分逻辑复杂,需修改业务代码

数据可拆分(如按用户 ID 分片)

读写分离

利用从节点资源,简单易行

主从延迟,集群模式不支持

读占比高,容忍延迟

目前已更新系列:

当前:Redis----大key、热key解决方案、脑裂问题

分布式---raft算法

分布式---CAP&&BASE理论

MySQL----BufferPool、redolog binlog两阶段提交

实习期间git的分枝管理以及最常用的命令-CSDN博客

Redis高级-----持久化AOF、RDB原理

Redis高级---面试总结5种数据结构的底层实现

Redis高级----主从、哨兵、分片、脑裂原理-CSDN博客

Redis高级---面试总结内存过期策略及其淘汰策略

计算机网络--面试知识总结一

计算机网络-----面试知识总结二

计算机网络--面试总结三(Http与Https)

计算机网络--面试总结四(HTTP、RPC、WebSocket、SSE)-CSDN博客

计算机网络-------重传、TCP流量控制、拥塞控制_tcp拥塞控制,拥塞避免-CSDN博客

知识积累之ThreadLocal---InheritableThreadLocal总结

分布式ID多种生成方式-CSDN博客

并发编程之----线程池ThreadPoolExecutor,Excutors的使用及其工作原理

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/73085.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

网络编程-----服务器(多路复用IO 和 TCP并发模型)

一、单循环服务器模型 1. 核心特征 while(1){newfd accept();recv();close(newfd);}2. 典型应用场景 HTTP短连接服务&#xff08;早期Apache&#xff09;CGI快速处理简单测试服务器 3. 综合代码 #include <stdio.h> #include <sys/types.h> /* See NO…

typora高亮方案+鼠标侧键一键改色

引言 在typora里面有一个自定义的高亮, <mark></mark>>但是单一颜色就太难看了, 我使用人工智能, 搜索全网艺术家, 汇集了几种好看的格式,并且方便大家侧键一键 调用, 是不是太方便啦 ! 示例 午夜模式 春意盎然 深海蓝调 石墨文档 秋日暖阳 蜜桃宣言 使用方法 …

swift -(5) 汇编分析结构体、类的内存布局

一、结构体 在 Swift 标准库中&#xff0c;绝大多数的公开类型都是结构体&#xff0c;而枚举和类只占很小一部分 比如Bool、 Int、 Double、 String、 Array、 Dictionary等常见类型都是结构体 ① struct Date { ② var year: Int ③ var month: Int ④ …

Java 大视界 -- Java 大数据在智能家居能源管理与节能优化中的应用(120)

&#x1f496;亲爱的朋友们&#xff0c;热烈欢迎来到 青云交的博客&#xff01;能与诸位在此相逢&#xff0c;我倍感荣幸。在这飞速更迭的时代&#xff0c;我们都渴望一方心灵净土&#xff0c;而 我的博客 正是这样温暖的所在。这里为你呈上趣味与实用兼具的知识&#xff0c;也…

【网络】TCP常考知识点详解

TCP报文结构 TCP报文由**首部&#xff08;Header&#xff09;和数据&#xff08;Data&#xff09;**两部分组成。首部包括固定部分&#xff08;20字节&#xff09;和可选选项&#xff08;最多40字节&#xff09;&#xff0c;总长度最大为60字节。 1. 首部固定部分 源端口&…

05.基于 TCP 的远程计算器:从协议设计到高并发实现

&#x1f4d6; 目录 &#x1f4cc; 前言&#x1f50d; 需求分析 &#x1f914; 我们需要解决哪些问题&#xff1f; &#x1f3af; 方案设计 &#x1f4a1; 服务器架构 &#x1f680; 什么是协议&#xff1f;为什么要设计协议&#xff1f; &#x1f4cc; 结构化数据的传输问题 …

《OpenCV》—— dlib(换脸操作)

文章目录 dlib换脸介绍仿射变换在 dlib 换脸中的应用 换脸操作 dlib换脸介绍 dlib 换脸是基于 dlib 库实现的一种人脸替换技术&#xff0c;以下是关于它的详细介绍&#xff1a; 原理 人脸检测&#xff1a;dlib 库中包含先进的人脸检测器&#xff0c;如基于 HOG&#xff08;方向…

江科大51单片机笔记【12】DS18B20温度传感器(上)

写在前言 此为博主自学江科大51单片机&#xff08;B站&#xff09;的笔记&#xff0c;方便后续重温知识 在后面的章节中&#xff0c;为了防止篇幅过长和易于查找&#xff0c;我把一个小节分成两部分来发&#xff0c;上章节主要是关于本节课的硬件介绍、电路图、原理图等理论…

基于springboot+vue的佳途旅行分享预约平台

一、系统架构 前端&#xff1a;vue2 | element-ui | html 后端&#xff1a;springboot | mybatis-plus 环境&#xff1a;jdk1.8 | mysql | maven | node 二、代码及数据库 三、功能介绍 01. web端-注册 02. web端-登录 03. web端-系统主页1 04. web端-系统主页2 05. we…

【数据结构】2算法及分析

0 章节 &#xff11;&#xff0e;&#xff14;到1&#xff0e;&#xff15;小节。 掌握算法概念、特性、描述、算法性能时间复杂度和空间复杂度&#xff1b; 理解递归含义&#xff1f; 掌握实现递归的条件和时机&#xff1b; 应用简单递归问题的算法设计&#xff1b; 重点 算法…

【一起学Rust | Tauri2.0框架】基于 Rust 与 Tauri 2.0 框架实现软件开机自启

文章目录 前言 一、准备工作1.1 环境搭建1.2 创建 Tauri 项目1.3 添加依赖 二、实现开机自启的基本原理2.1 开机自启的基本概念2.2 Tauri 应用的生命周期 三、Windows 平台实现3.1 Windows 注册表机制3.2 实现步骤3.3 注意事项 四、Linux 平台实现4.1 Linux systemd 服务4.2 实…

一周热点-OpenAI 推出了 GPT-4.5,这可能是其最后一个非推理模型

在人工智能领域,大型语言模型一直是研究的热点。OpenAI 的 GPT 系列模型在自然语言处理方面取得了显著成就。GPT-4.5 是 OpenAI 在这一领域的又一力作,它在多个方面进行了升级和优化。 1 新模型的出现 GPT-4.5 目前作为研究预览版发布。与 OpenAI 最近的 o1 和 o3 模型不同,…

element-plus中form表单组件的使用

1.如何让每个表单项对齐&#xff1f; 问题描述&#xff1a;如下图&#xff0c;每个表单项的输入框/下拉框/日期选择器是没有对齐的&#xff0c;我们希望它们纵向是对齐的。 解决方案&#xff1a;给el-form标签&#xff0c;加上label-width"100px"即可。意思就是给每个…

OpenManus-通过源码方式本地运行OpenManus,含踩坑及处理方案,chrome.exe位置修改

前言&#xff1a;最近 Manus 火得一塌糊涂啊&#xff0c;OpenManus 也一夜之间爆火&#xff0c;那么作为程序员应该来尝尝鲜 1、前期准备 FastGithub&#xff1a;如果有科学上网且能正常访问 github 则不需要下载此软件&#xff0c;此软件是提供国内直接访问 githubGit&#…

【最新】DeepSeek 实用集成工具有那些?

deepseek 系列github仓库地址 【主页】deepseek-aiDeepSeek-R1DeepSeek-V3DeepSeek-VL2【本文重点介绍】awesome-deepseek-integration 注意&#xff1a;以下内容来自awesome-deepseek-integration DeepSeek 实用集成&#xff08;awesome-deepseek-integration&#xff09; 将…

开源!速度100Kb/s的有线和无线双模ESP32S3芯片的DAP-Link调试器

开源&#xff01;速度100Kb/s的有线和无线双模ESP32S3芯片的DAP-Link调试器 目录 开源&#xff01;速度100Kb/s的有线和无线双模ESP32S3芯片的DAP-Link调试器本项目未经授权&#xff0c;禁止商用&#xff01;本项目未经授权&#xff0c;禁止商用&#xff01;本项目未经授权&…

Flink测试环境Standalone模式部署实践

1.JDK环境 参考官方文档&#xff1a; https://nightlies.apache.org/flink/flink-docs-release-1.20/release-notes/flink-1.18/ 2.下载Flink&#xff1a;https://flink.apache.org/downloads/ 本次验证用的是&#xff1a;https://www.apache.org/dyn/closer.lua/flink/flink…

macOS 终端优化

macOS 安装、优化、还原、升级 Oh My Zsh 完全指南 &#x1f680; Oh My Zsh 是 macOS 终端增强的利器&#xff0c;它能提供强大的自动补全、主题定制和插件支持&#xff0c;让你的终端更高效、更炫酷。本文将全面介绍 如何安装、优化、还原、重新安装和升级 Oh My Zsh&#x…

计算机网络--访问一个网页的全过程

文章目录 访问一个网页的全过程应用层在浏览器输入URL网址http://www.aspxfans.com:8080/news/index.aspboardID5&ID24618&page1#r_70732423通过DNS获取IP地址生成HTTP请求报文应用层最后 传输层传输层处理应用层报文建立TCP连接传输层最后 网络层网络层对TCP报文进行处…

【BUG】类文件具有错误的版本 61.0, 应为 52.0,请删除该文件或确保该文件位于正确的类路径子目录中。

报错&#xff1a; [ERROR] 类文件具有错误的版本 61.0, 应为 52.0 [ERROR] 请删除该文件或确保该文件位于正确的类路径子目录中。 报错截图&#xff1a; 原因&#xff1a;Java 版本和 Spring 不兼容&#xff0c;显示 Spring 版本过高 解决方法 1. 使用更高版本的 J…