缓存穿透、击穿、雪崩

一、缓存穿透

缓存穿透指的是大量请求缓存中不存在的数据,直接访问数据库,造成数据库压力过大,会使别的用户的正常请求时间过长,效率低下。

解决方法

1.设置空key,请求访问数据库不存在后在redis中设置一个key value设置为null,缺点是比较浪费空间。

2.布隆过滤器

存在的问题:

这样会存在一个问题,如果并发很多请求,因为redis是串行的,设置空value是在串行的请求结束之后进行的。那时候这样串行的请求已经全部打在数据库了。解决办法就是加上分布式锁,如果redis没有缓存,就去抢锁,同一时刻只有一个请求能抢到锁,这样请求到数据库中的只有一个请求,就避免了数据库的压力

二、缓存击穿

热点key过期(或者从来没有被缓存的),数据库存在数据,但是redis没有缓存,有大量的并发到达db。

解决办法

其实和缓存穿透一样的问题,一样的解决办法,主要就是添加分布式锁。

三、缓存雪崩

大量的key在同一时间失效,请求全部打在db

解决办法

简单的就是采用合理的过期时间了,复杂点的就是和上面两个问题一样采用分布式锁解决

四、两个问题的解决步骤步骤

1、请求redis没有数据
2、并发抢锁
3、抢到锁的请求db
4、没抢到的sleep
5、更新redis
6、回到第一步再请求redis就有数据了

以上问题,核心就是避免DB无效/重复请求,结合图去理解
涉及一些架构思想上的提升

你可能感兴趣的:(缓存,redis,数据库)