news 2026/4/23 5:17:23

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

作者头像

张小明

前端开发工程师

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/23 8:18:43

AI助力Conda安装:一键解决Python环境配置难题

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容: 创建一个AI辅助的Conda安装助手,能够根据用户输入的Python版本、所需库列表和操作系统类型,自动生成最优的Conda安装命令和配置建议。功能包括:…

作者头像 李华
网站建设 2026/4/23 8:19:56

零基础教程:3步搞定CENTOS7.9下载与验证

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容: 制作一个交互式命令行向导程序,功能包括:1) 分步骤引导用户选择CENTOS7.9版本(x86_64/aarch64) 2) 显示镜像站选择菜单 3) 自动验证GPG签名 4) 生成简易校验…

作者头像 李华
网站建设 2026/4/22 14:13:26

Docker Desktop零基础入门:一小时学会容器化开发

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容: 开发一个交互式Docker学习应用,包含:1) 可视化Docker概念讲解(容器/镜像/仓库) 2) 图形化Docker Desktop界面导览 3) 拖拽式Dockerfile生成器 4) 预设的初学…

作者头像 李华
网站建设 2026/4/23 8:22:59

KNIFE4J入门指南:5分钟快速生成你的第一个API文档

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容: 创建一个简单的KNIFE4J入门教程项目,包含一个基础的SpringBoot REST API(如“Hello World”接口)。要求项目配置好KNIFE4J,并生成对…

作者头像 李华
网站建设 2026/4/23 11:32:32

AVNIGHT:AI如何革新音视频开发流程

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容: 创建一个基于AVNIGHT的AI音视频处理平台,支持自动视频剪辑、智能字幕生成、实时降噪和画质增强功能。平台需集成Kimi-K2模型进行语音识别和翻译,DeepSeek模…

作者头像 李华
网站建设 2026/4/23 9:56:16

清华镜像站同步上线VibeVoice-WEB-UI,下载提速10倍

清华镜像站上线 VibeVoice-WEB-UI:长时多角色语音合成新范式 在播客制作人还在为录制三人对谈音频反复剪辑、教育内容开发者苦恼于单调的AI朗读声、游戏工作室疲于应对海量NPC对话配音的时代,一个真正能“理解对话”的语音生成系统悄然浮现。 VibeVoice-…

作者头像 李华