Redis之缓存雪崩问题
这里是允谦的学习之路
👍如果对你有帮助,给博主一个免费的点赞以示鼓励把QAQ
👋博客主页🎉 允谦的学习小屋
⭐️更多文章👨🎓请关注允谦主页📝
🍅文章发布日期:2022.03.01
👋java学习之路!
欢迎各位🔎点赞👍评论收藏⭐️
🎄冲冲冲、持续更新🎄
文章目录
问题描述
key 对应的数据存在,但在redis 中过期,此时若有大量并发请求过来,这些请求发现缓存过期一般都会从后端DB加载数据并回设到缓存,这个时候大并发的请求可能会瞬间把后端DB压垮。,
缓存雪崩与缓存击穿的区别在于这里针对很多key
缓存,前者则是某一个key正常访问。
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-StNvMs8j-1646137287269)(C:\Users\WANG\AppData\Roaming\Typora\typora-user-images\image-20220301201528887.png)]
解决方法
(1)构建多级缓存架构:ngix缓存+redis缓存+其他缓存
(2)使用锁或队列:用加锁或者队列的方式保证来保证不会有大量的线程对数据库一次性进行读写,从而避免失效时大量的并发请求落到底层存储系统上。不适用高并发情况
(3)设置过期标志更新缓存:记录缓存数据是否过期(设置提前量),如果过期会触发通知另外的线程在后台去更新实际key的缓存
的线程在后台去更新实际key的缓存
(4)将缓存失效时间分散开:比如我们可以在原有的失效时间基础上增加一个随机值,比如1-5分钟随机,这样每一个缓存的过期时间的重复率就会降低,就很难引发集体失效的事件。