news 2026/2/6 19:51:08

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

作者头像

张小明

前端开发工程师

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/2/6 14:00:16

1小时原型开发:TDAPPDESKTOP验证产品创意

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容: 快速开发一个社交媒体监控工具原型,功能包括:1. 关键词搜索面板 2. 实时数据抓取展示 3. 情感分析可视化 4. 警报通知系统 5. 简易仪表盘。优先实现核心交互…

作者头像 李华
网站建设 2026/1/30 12:36:34

超越VLOOKUP:这些高效替代方案你知道吗?

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容: 创建一个Excel函数性能对比工具,能够:1. 自动生成不同规模测试数据(从100行到100万行);2. 使用VLOOKUP、INDEXMATCH、XL…

作者头像 李华
网站建设 2026/2/2 17:44:21

小白必看:CentOS7最安全下载安装图解教程

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容: 制作交互式CentOS7下载安装向导,包含:1.官网认证指引 2.镜像类型说明(Minimal/DVD/Everything)3.校验码验证教程 4.USB制作工具推荐…

作者头像 李华
网站建设 2026/1/30 19:43:31

传统调试 vs AI辅助:解决405错误效率对比

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容: 创建一个405错误解决效率对比工具,包含:1)传统调试模拟器:手动检查请求、服务器配置、查文档等步骤 2)AI辅助模式:自动分析并给出解…

作者头像 李华
网站建设 2026/1/30 20:26:13

AI助力快速获取OPENSSH:自动生成下载与配置脚本

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容: 创建一个Python脚本,自动从OPENSSH官网下载最新版本的SSH客户端和服务端,并完成基本的配置。脚本需要包含以下功能:1. 检测当前操作系统类型&am…

作者头像 李华
网站建设 2026/2/6 6:03:34

GitHub镜像网站推荐:快速获取VibeVoice开源项目源码

VibeVoice-WEB-UI:如何用低帧率语音表示与对话式生成重塑长文本TTS 在播客制作间里,两位主播正为下一期节目反复录制——语气不对重来,角色切换生硬再录,三万字脚本整整磨了三天。这样的场景,在内容创作领域并不罕见。…

作者头像 李华