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

redis 缓存命中率降低,该如何解决?

命中率降低

Redis 缓存命中率降低,可能是由于多个因素导致的,比如缓存未命中、缓存污染、缓存淘汰过快等。针对不同情况,可以采取以下优化措施:

1. 分析缓存命中率下降的原因

在优化之前,先使用 Redis 监控工具 分析命中率下降的具体原因:

redis-cli info stats | grep "keyspace_hits\|keyspace_misses"
  • keyspace_hits 表示缓存命中次数
  • keyspace_misses 表示缓存未命中次数
  • 计算缓存命中率
    在这里插入图片描述

2. 减少缓存穿透

问题:请求的 Key 在缓存和数据库中都不存在,导致每次请求都要查询数据库,增加 keyspace_misses

解决方案

  • 布隆过滤器(Bloom Filter)
    在 Redis 之前使用 布隆过滤器 存储可能存在的 Key,避免无效查询:
    import com.google.common.hash.BloomFilter;
    import com.google.common.hash.Funnels;BloomFilter<Integer> bloomFilter = BloomFilter.create(Funnels.integerFunnel(), 100000);
    bloomFilter.put(12345); // 预存 Key
    if (!bloomFilter.mightContain(54321)) {return "数据不存在"; // 直接返回,避免数据库查询
    }
    
  • 缓存空值
    例如,对于查询不到的 Key 存入一个短 TTL(如 60s)的空值:
    SET key "null" EX 60
    
    风险:要避免缓存大量空值,占用 Redis 内存。

3. 减少缓存击穿

问题:某个热点 Key 失效后,短时间内大量请求击中数据库,导致 Redis 负载降低,数据库压力激增。

解决方案

  • 设置热点 Key 的自动续期(使用 逻辑过期+异步重建
    String value = redis.get("hot_key");
    if (value == null) {if (redis.setNx("lock_hot_key", "1", 10)) { // 尝试获取锁value = dbQuery(); // 查询数据库redis.setEx("hot_key", value, 60); // 重新缓存redis.del("lock_hot_key"); // 释放锁} else {Thread.sleep(100); // 等待其他线程加载完成value = redis.get("hot_key");}
    }
    
  • 预加载数据
    • 提前加载热点数据到 Redis,避免突然失效带来的冲击。
    • 使用 Lua 脚本 实现 原子性 续期:
      local ttl = redis.call("TTL", KEYS[1])
      if ttl > 0 thenredis.call("EXPIRE", KEYS[1], ttl + 30) -- 续期 30s
      end
      

4. 减少缓存雪崩

问题:大量 Key 同时过期,导致 Redis 负载骤降,数据库压力激增。

解决方案

  • 设置随机过期时间,避免同一时刻大量 Key 失效:
    redis.setEx("key", value, 60 + new Random().nextInt(30)); // 60-90s 随机过期
    
  • 分批加载缓存
    • 在高并发场景下,采用 预热缓存 的方式,在系统启动或数据更新时提前加载缓存。

5. 优化缓存淘汰策略

问题:Redis 可能因为 内存不足 频繁淘汰数据,导致缓存命中率下降。

解决方案

  • 调整淘汰策略
    • volatile-lru淘汰最近最少使用的 key
    • allkeys-lru淘汰所有 key 中最近最少使用的
    • volatile-ttl优先淘汰快过期的 key
    • allkeys-random随机淘汰
    • 设置适合的 maxmemory-policy
      CONFIG SET maxmemory-policy allkeys-lru
      
  • 使用大 Key 拆分
    • 如果某个 Key 过大(如存储了整个用户历史数据),可拆分成多个小 Key,减少单 Key 失效影响。

6. 提升 Redis 读取性能

问题:如果 Redis 本身读取性能下降,也可能导致命中率降低。

解决方案

  • 优化数据结构
    • 使用 Hash 代替 String
      redis.hset("user:1001", "name", "Alice");
      redis.hset("user:1001", "age", "25");
      
    • 减少大 Key 读取,如 List, Set, Zset,避免一次性加载大量数据。
  • 开启 Redis 读写分离
    • 部署 Redis 主从架构,让从节点分担读取压力:
      redis-cli -h master-ip replicaof slave-ip 6379
      
    • 在 Spring Boot 代码中配置多个 Redis 连接:
      spring:redis:cluster:nodes: 192.168.1.1:6379,192.168.1.2:6379,192.168.1.3:6379
      

总结

问题优化方案
缓存穿透布隆过滤器、缓存空值
缓存击穿热点数据续期、逻辑过期、预加载
缓存雪崩随机过期时间、分批加载
缓存淘汰调整淘汰策略、拆分大 Key
Redis 读写读写分离、优化数据结构

Redis 命中率下降的根本原因在于 缓存未命中次数增加缓存数据被频繁淘汰,针对不同的情况,可以结合 预防 + 限流 + 监控 + 读写分离 等手段优化。

如果你的 Redis 缓存命中率持续降低,可以具体分析 请求 Key 的访问分布、数据更新频率、查询模式,再针对性优化。🚀

穿透、击穿、雪崩

缓存穿透:请求一个不存在的数据,导致请求直接到达数据库。
解决方案:对空值缓存,使用布隆过滤器,拦截不存在的请求,避免数据库查询。

缓存击穿:在高并发下,某个数据的缓存失效,导致大量请求同时访问数据库。
解决方案:对热点数据加锁(分布式锁),或使用互斥锁(分布式锁),确保在缓存更新时只允许一个请求访问数据库。

缓存雪崩:大量缓存同时过期,导致瞬间大量请求涌向数据库。
解决方案:设置不同的过期时间,随机化缓存的过期时间,避免集中失效。

相关文章:

redis 缓存命中率降低,该如何解决?

命中率降低 Redis 缓存命中率降低&#xff0c;可能是由于多个因素导致的&#xff0c;比如缓存未命中、缓存污染、缓存淘汰过快等。针对不同情况&#xff0c;可以采取以下优化措施&#xff1a; 1. 分析缓存命中率下降的原因 在优化之前&#xff0c;先使用 Redis 监控工具 分析…...

LiteDB 数据存储与检索效率优化的最佳实践指导

一、引言 在当今数字化时代,数据处理和存储变得至关重要。对于小型项目或者嵌入式系统而言,需要一种轻量级、高效且易于使用的数据库解决方案。LiteDB 作为一款嵌入式的 NoSQL 数据库,因其零配置、易于集成等特点,受到了开发者的青睐。然而,若要充分发挥其性能优势,就需…...

数据结构——Map和Set

1. 搜索树 1. 概念 ⼆叉搜索树⼜称⼆叉排序树&#xff0c;它可以是⼀棵空树&#xff0c;或者是具有以下性质的⼆叉树: • 若它的左⼦树不为空&#xff0c;则左⼦树上所有节点的值都⼩于根节点的值 • 若它的右⼦树不为空&#xff0c;则右⼦树上所有节点的值都⼤于根节点的值…...

树莓派超全系列文档--(18)树莓派配置音频

这里写目录标题 音频更改音频输出通过桌面音量控制专业音频设备配置文件 通过 raspi-config 文章来源&#xff1a; http://raspberry.dns8844.cn/documentation 原文网址 音频 Raspberry Pi OS 有多种音频输出模式&#xff1a; 默认情况下&#xff0c;Raspberry Pi OS 将音频…...

Flutter中实现拍照识题的功能

文章目录 **1. 功能拆解****2. 具体实现步骤****(1) 拍照或选择图片****(2) 图片预处理&#xff08;可选&#xff09;****(3) 文字识别&#xff08;OCR&#xff09;****(4) 数学公式识别 → LaTeX****方案1&#xff1a;Mathpix API&#xff08;高精度&#xff0c;付费&#xff…...

装饰器模式:如何用Java打扮一个对象?

引言装饰器模式具体实例共有接口类具体被装饰类抽象装饰器类具体装饰器类 测试装饰器模式的实际应用Java I/O 体系游戏开发中的角色装备系统 总结 引言 在生活中&#xff0c;我们都知道一句话&#xff0c;“人靠衣装马靠鞍”&#xff0c;如果想要让自己在别人眼里看起来更加好…...

OpenCV 图形API(或称G-API)(1)

操作系统&#xff1a;ubuntu22.04 OpenCV版本&#xff1a;OpenCV4.9 IDE:Visual Studio Code 编程语言&#xff1a;C11 引言 OpenCV 图形API&#xff08;或称G-API&#xff09;是一个新的OpenCV模块&#xff0c;旨在使常规图像处理更快且更便携。通过引入一种新的基于图的执行…...

学以致用,基于OpenCV的公摊面积估算程序

由于很多户型图并没有标注各个房间或者走廊的面积&#xff0c;亦或比较模糊&#xff0c;且很多人并不具备迅速口算多个小数相加再做除法的能力&#xff0c;本帖通过程序粗略计算公摊比例。由于非专业人士&#xff0c;公摊面积涉及到很多建筑学的专业公式&#xff0c;因此本帖只…...

爬虫:网络请求(通信)步骤,http和https协议

电脑(浏览器)&#xff1a;www.baidu.com——url DNS服务器&#xff1a;IP地址标注服务器——1.1.38 DNS服务器返回IP地址给浏览器 浏览器拿到IP地址去访问服务器&#xff0c;返回响应 服务器返回给响应数据&#xff1a;html/css/js/jpg... html&#xff1a;文本 cs…...

d2025331

目录 一、删除有序数组中的重复项II 二、删除有序数组中的重复项 三、数字转罗马格式 一、删除有序数组中的重复项II 一下写过&#xff0c;挺舒服&#xff01; 1、统计超出2的数量有多少&#xff0c;仅保留2个重复数字 2、有多少次就从后往前覆盖几次 public int removeDupl…...

QT6开发指南笔记(1)QT简介,安装

&#xff08;1&#xff09;刚刚结束了 C 的学习&#xff0c;谢谢阿西老师的教导&#xff0c;开始 QT 的学习&#xff0c;运用 C &#xff0c;而非 QML 。 保持知识的连贯性。 QT 公司 &#xff1a; &#xff08;2&#xff09;接着介绍 QT 的安装&#xff1a; 提取到的…...

Redis BitMap 实现签到及连续签到统计

一、引言 用户签到功能是很多应用都离不开的一个板块&#xff0c;单词打开、QQ达人等等为我们所熟知&#xff0c;这项功能该如何实现呢&#xff0c;一些朋友可能想当然的觉得无非将每日的签到数据记录下来不就好了&#xff0c;不会去细想用谁记录&#xff0c;如何记录才合适。 …...

全面解析 Spring AOP 切入点表达式

全面解析 Spring AOP 切入点表达式 大家好&#xff0c;我是钢板兽&#xff01; Spring AOP&#xff08;面向切面编程&#xff09;是我们日常开发中实现日志记录、权限控制、事务管理等功能的神器。而切入点表达式&#xff08;Pointcut Expression&#xff09;则是这个神器的“…...

去中心化稳定币机制解析与产品策略建议

去中心化稳定币机制解析与产品策略建议&#xff08;以Maker/DAI为例&#xff09; 一、核心机制对比&#xff1a;法币抵押型 vs. 加密货币抵押型 法币抵押型&#xff08;如USDT&#xff09; 技术逻辑&#xff1a;1:1美元储备托管于中心化机构&#xff08;如银行&#xff09;&…...

GO语言杂记(文章持续更新)

1、MAIN冲突 在一个文件夹下有两个go文件同时写了main函数&#xff0c;将会报错&#xff0c;main函数只能在main包中。 实则不然&#xff0c;有些环境下并不会报错。 2、gofmt命令---自动对齐 命令作用&#xff1a;将go文件代码自动缩进。 gofmt -w escapecharprac.go...

OS6.【Linux】基本指令入门(5)

目录 1.配置公网IP到XShell中 2.日志 定义和作用 3.一些指令 date %Y、%m、%d、%H、%M、%S、%X、%F %s 时间戳的特点 时间戳的转换 cal cal 年份 其他选项 ★find★ whereis grep 练习 -v选项 -n选项 -i选项 多文件查找 特定目录下查找 1.配置公网IP到XShe…...

Moo0 VideoResizer,简单高效压缩视频!

Moo0 VideoResizer 是一款免费、轻量级的视频压缩工具&#xff0c;支持通过调整文件大小、屏幕尺寸或比特率等方式实现高效视频压缩。其核心优势在于操作简单且无需破解&#xff0c;可直接下载安装使用‌。软件注重用户友好性&#xff0c;采用非破坏性压缩技术&#xff0c;所有…...

【开发问题记录】高德地图 Web 端开发详解:高德地图 API 最佳实践指南(安装、marker添加、逆向地理编码、实际业务案例实操)

文章目录 1、引入高德地图的准备工作2、高德地图 JS API 使用方式2.1 JS API Loader2.1.1 使用 script 标签加载loader2.1.2 NPM 安装loader 2.2 script 标签加载 JS API 脚本2.2.1 同步加载2.2.2 异步加载 3、在 vue3 项目中使用3.1 安装 js api loader3.2 在组件中使用 4、实…...

Unity 简单使用Addressables加载SpriteAtlas图集资源

思路很简单&#xff0c;传入图集名和资源名&#xff0c;利用Addressables提供的异步加载方式从ab包中加载。加载完成后存储进缓存字典里&#xff0c;以供后续使用。 添加引用计数&#xff0c;防止多个地方使用同一图集时&#xff0c;不会提前释放 using UnityEngine; using U…...

LangChain 结构化输出:用 Pydantic + PydanticOutputParser 驯服 LLM 的“自由发挥”

目录 一、Pydantic 二、PydanticOutputParser 1、为什么需要 PydanticOutputParser&#xff1f; 2、Pydantic和PydanticOutputParser核心区别 3、Pydantic的不足 &#xff08;1&#xff09;无法直接解析非结构化文本 &#xff08;2&#xff09;缺乏对 LLM 输出的适配性 …...

快速入手-基于Django-rest-framework的自身组件权限认证(九)

1、在对应的视图函数里增加认证&#xff08;局部起作用&#xff0c;不全局生效&#xff09; 导入类&#xff1a; from rest_framework.authentication import ( BasicAuthentication, SessionAuthentication, ) from rest_framework.permissions import IsAuthentica…...

【复活吧,我的爱机!】Ideapad300-15isk拆机升级:加内存条 + 换固态硬盘 + 换电源

写在前面&#xff1a;本博客仅作记录学习之用&#xff0c;部分图片来自网络&#xff0c;如需引用请注明出处&#xff0c;同时如有侵犯您的权益&#xff0c;请联系删除&#xff01; 文章目录 前言升级成本升级流程电池健康度加内存条和换内存条光驱位加装机械硬盘更换电池重装系…...

基于Spring AI开发本地Jenkins MCP Server服务

前言 首先介绍下MCP是什么&#xff1f; MCP是由开发了 Claude 模型的 Anthropic 公司2024年11月提出并开源的一项开放标准&#xff0c;全称&#xff1a;Model Context Protocol&#xff0c;它是一个开放协议&#xff0c;它使 LLM 应用与外部数据源和工具之间的无缝集成成为可能…...

基于简单神经网络的线性回归

一、概述 本代码实现了一个简单的神经网络进行线性回归任务。通过生成包含噪声的线性数据集&#xff0c;定义一个简单的神经网络类&#xff0c;使用梯度下降算法训练网络以拟合数据&#xff0c;并最终通过可视化展示原始数据、真实线性关系以及模型的预测结果。 二、依赖库 …...

【nvidia】Windows 双 A6000 显卡双显示器驱动更新问题修复

问题描述&#xff1a;windows自动更新nvidia驱动会导致只检测得到一个A6000显卡。 解决方法 下载 A6000 驱动 572.83-quadro-rtx-desktop-notebook-win10-win11-64bit-international-dch-whql.exehttps://download.csdn.net/download/qq_18846849/90554276 不要直接安装。如…...

《SRv6 网络编程:开启IP网络新时代》第2章、第3章:SRv6基本原理和基础协议

背景 根据工作要求、本人掌握的知识情况&#xff0c;仅针对《SRv6 网络编程&#xff1a;开启IP网络新时代》书籍中涉及的部分知识点进行总结梳理&#xff0c;并与工作小组进行分享&#xff0c;不涉及对原作的逐字搬运。 问题 组内同事提出的问题&#xff1a;本文缺扩展头描述…...

如何将AI模型返回的字符串转为html元素?

场景&#xff1a; 接入deepseek模型的api到我们平台&#xff0c;返回的字符串需要做下格式化处理。 返回的数据是这样的&#xff1a; {"role": "assistant","content": "<think>\n嗯&#xff0c;用户问的是“星体是什么”。首先&am…...

Citus源码(1)分布式表行为测试

最近对citus的实现非常好奇&#xff0c;本篇对citus的行为做一些测试。本篇只测行为&#xff0c;不分析源码。后面会继续写一系列文章分析citus源码。 环境&#xff1a;3节点 PG17 with citus。 SELECT citus_set_coordinator_host(127.0.0.1, 3001); SELECT citus_add_node(1…...

装饰器模式与模板方法模式实现MyBatis-Plus QueryWrapper 扩展

pom <dependency><groupId>com.github.yulichang</groupId><artifactId>mybatis-plus-join-boot-starter</artifactId> <!-- MyBatis 联表查询 --> </dependency>MPJLambdaWrapperX /*** 拓展 MyBatis Plus Join QueryWrapper 类&…...

【PCIE711-214】基于PCIe总线架构的4路HD-SDI/3G-SDI视频图像模拟源

产品概述 PCIE711-214是一款基于PCIE总线架构的4路SDI视频模拟源。该板卡为标准的PCIE插卡&#xff0c;全高尺寸&#xff0c;适合与PCIE总线的工控机或者服务器&#xff0c;板载协议处理器&#xff0c;可以通过PCIE总线将上位机的YUV 422格式视频数据下发通过SDI接口播放出去&…...