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

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

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

解决方法常用的有两种

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

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

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

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

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

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

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

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

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

相关推荐
tq10862 小时前
通用数据引用表示法:基于协议-URI-JSONPath的简洁数据定位规范
数据库
+VX:Fegn08952 小时前
计算机毕业设计|基于springboot + vue律师咨询系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·后端·课程设计
manuel_897572 小时前
六 系统安全
网络·数据库·系统安全
液态不合群3 小时前
【面试题】MySQL 三层 B+ 树能存多少数据?
java·数据库·mysql
困知勉行19854 小时前
springboot整合redis
java·spring boot·redis
龙亘川4 小时前
【课程5.1】城管住建核心功能需求分析:市政设施、市容秩序等场景痛点拆解
数据库·oracle·智慧城市·城管住建
飞鸟真人5 小时前
Redis面试常见问题详解
数据库·redis·面试
fanruitian5 小时前
Springboot项目父子工程
java·数据库·spring boot
super_lzb5 小时前
mybatis拦截器ParameterHandler详解
java·数据库·spring boot·spring·mybatis
CV工程师的自我修养6 小时前
数据库出现死锁了。还不知道什么原因引起的?快来看看吧!
数据库