news 2026/4/16 10:00:15

缓存穿透、缓存击穿、缓存雪崩

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
缓存穿透、缓存击穿、缓存雪崩

什么是缓存穿透?如何解决?

缓存穿透就是大量请求去访问数据库与缓存中都不存在的数据,因为数据库不存在,缓存肯定不存在就不生效,所有请求最终都流转到了数据库,导致数据库压力过大而宕机。

解决方法常用的有两种

第一种简单的就是缓存空值。当请求的数据缓存与数据库都没有时,就将空值缓存到Redis,这样再查这样的数据时就不会流转到数据库。

第二种方法是使用布隆过滤器,布隆过滤器是一种基于hash的算法。首先有好几种不一样的hash函数,来计算数据对应的hashcode。不同的算法计算出不同的值。然后把这些结果映射到一个很长的bit数组置为1。我们想判断某个值是否存在时就让他再被这几个hash函数运算一次,那到hash值后去bit数组查验这些位置是不是都是1。如果全是1就证明这个数据存在。针对于布隆过滤器的这种特性,我们可以把数据库的数据都用布隆过滤器标记出来,当缓存中没有请求的数据时,就先基于布隆过滤器判断,布隆认定不存在就拒绝这个请求,如果存在就让访问数据库。尽管布隆过滤器有多重hash函数来求hash值,但还是有可能会有hash冲突。但这个概率非常小,我们通常忽略不计。

什么是缓存击穿?如何解决?

缓存击穿就是有一个高并发访问的数据突然失效了,并且重建缓存期间导致大量的请求涌入数据库,而压垮数据库的问题。解决缓存击穿的常用方案有两种。

第一种是逻辑过期,就是说对于热点数据过期之后不要立马删除,等到热度过去之后手动删除。就是说但有请求访问时,发现这个数据过期了,然后就开启一个异步线程去重建缓存数据,同时给这个请求返回还没有删除的旧数据。当有别的请求来的时候都给他们返回旧数据。并且为了防止别的线程发现数据过期也要开启异步异步线程重构缓存,我们通常会加锁,确保一个线程重构缓存的时候别的线程不能重构。

第二种方案就是加锁。当一个线程发现缓存数据失效之后,要先拿到锁,然后才能去重构缓存,然后再释放锁。在重构过程中要是有其他线程想访问缓存资源时会让他们休眠一会然后重试直到锁被释放,然后他们就可以从缓存中拿到数据。

什么是缓存雪崩?如何解决?

缓存雪崩就是指同一时间段内大量数据失效或者redis宕机,导致大量请求进入到数据库,压垮数据库。

解决缓存雪崩问题的常见方案有:①给数据设置过期时间的时候不要设置大量相同的,这样就可以防止同一时间大量数据失效。②搭建redis集群,当一个服务宕机时,立刻有另一个服务顶上来。③可以给缓存业务设置限流策略。④使用多级缓存,比如同时设置本地缓存与redis缓存。访问时先在本地查,本地没有然后去redis查,redis没有才会流转到数据库。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/15 10:41:27

FLEX布局VS传统布局:开发效率提升300%的秘诀

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容: 创建两个功能相同的页面布局对比Demo:1) 第一个使用传统float/position实现 2) 第二个使用FLEX布局实现 3) 都包含头部、侧边栏、内容区和页脚 4) 实现相同的响应式效果…

作者头像 李华
网站建设 2026/4/10 20:02:28

邮件订阅系统:定期发送版本发布和技术文章

VibeVoice-WEB-UI:如何让AI“说”出自然的长篇对话 在播客越来越像一档真实圆桌讨论、有声书开始追求角色情绪张力的今天,传统的文本转语音(TTS)系统显得有些力不从心。你有没有试过用普通语音合成工具生成一段三人以上的访谈&…

作者头像 李华
网站建设 2026/4/10 9:34:13

VibeVoice-WEB-UI音色一致性优化机制深度解读

VibeVoice-WEB-UI音色一致性优化机制深度解读 在AI内容创作的浪潮中,我们早已不再满足于让机器“念字”。真正打动用户的,是那些听起来像真实人物之间自然交流的声音——有节奏、有情绪、角色分明且贯穿始终。然而,传统文本转语音&#xff08…

作者头像 李华
网站建设 2026/4/10 7:22:55

前端新手必学:JS URL编码从入门到精通

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容: 创建一个交互式JS URL编码学习工具,要求:1. 提供编码/解码双向转换 2. 可视化显示特殊字符处理 3. 对比encodeURI和encodeURIComponent差异 4. 内置常见用例…

作者头像 李华
网站建设 2026/4/16 3:11:15

快速验证MODBUS RTU通信:5分钟搭建测试环境

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容: 生成一个快速搭建MODBUS RTU通信测试环境的代码示例。包括模拟主站和从站的Python脚本,支持基本的读写寄存器操作,并提供实时通信日志输出,便于…

作者头像 李华
网站建设 2026/4/5 13:32:15

ENSP下载安装效率提升300%的AI方案

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容: 设计一个ENSP智能安装优化工具。自动检测系统环境,并行下载所需组件;智能选择最佳镜像站点;自动解决常见安装问题(如WinPcap兼容性&…

作者头像 李华