码迷,mamicode.com
首页 > 其他好文 > 详细

Redis缓存常见问题

时间:2020-04-20 01:34:40      阅读:102      评论:0      收藏:0      [点我收藏+]

标签:空值   key   内存数据   不同的   redis   出现   http   工作   库存   

缓存击穿

缓存中没有但数据库中有的数据(一般是缓存时间到期),同时高并发读缓存没读到数据,又同时去数据库去取数据,引起数据库压力瞬间增大

解决

1.设置热点数据永远不过期。
2.加互斥锁,没有命中缓存的时候,加锁访问数据库,不造成数据库的瞬间压力

缓存穿透

用户想要查询一个数据,发现redis内存数据库没有,也就是缓存没有命中,于是向持久层数据库查询。发现也没有,于是本次查询失败。当用户很多的时候,缓存都没有命中,于是都去请求了持久层数据库。这会给持久层数据库造成很大的压力,这时候就相当于出现了缓存穿透。

解决

1.使用布隆过滤器。
布隆过滤器简单理解就是将数据库存在的东西映射到一个bitmap(位图)上,方位先查询有没有,有再访问,没有就直接返回。
布隆过滤器详解参考:https://segmentfault.com/a/1190000016721700
2.设置空值缓存
当存储层不命中后,即使返回的空对象也将其缓存起来,同时会设置一个过期时间,之后再访问这个数据将会从缓存中获取,保护了后端数据源。

缓存雪崩

缓存雪崩是指,缓存层出现了错误,不能正常工作了。于是所有的请求都会达到存储层,存储层的调用量会暴增,造成存储层也会挂掉的情况。

解决

1.redis高可用,搭建的集群。
2.限流降级,控制读数据库写缓存的线程数量。
3.数据预热,大并发访问前手动触发加载缓存不同的key,设置不同的过期时间,让缓存失效的时间点尽量均匀。

Redis缓存常见问题

标签:空值   key   内存数据   不同的   redis   出现   http   工作   库存   

原文地址:https://www.cnblogs.com/farmersun/p/12735269.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!