博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
redis缓存穿透和缓存雪崩
阅读量:5129 次
发布时间:2019-06-13

本文共 570 字,大约阅读时间需要 1 分钟。

缓存穿透

原因:用户查询数据库中根本就没有的数据,缓存中自然也就没有,这样每次用户的查询都会去数据库查一次

解决办法:

  • 第一次从数据库没查到,则在缓存设置一个空值或默认值,并返回默认值;这样后面的请求就不会再查数据库了

缓存雪崩

原因:大量缓存同一时间失效,导致所有的请求都跑去查数据库,导致数据库IO、内存、CPU压力过大,甚至系统崩溃

解决办法:

  • 对查数据库加锁,集群环境只能用分布式锁(主要应对缓存并发问题)
  • 对缓存的更新放到后端线程队列中处理
  • 对缓存的过期时间加上一个随机数,让缓存过期时间均匀分布
  • 缓存永远不过期,意思是缓存不设置过期时间,但是在value中有一个过期时间字段;后台线程扫描到value中的时间字段即将过期的时候,重新构建缓存,如果发现数据库没查到,则删除缓存,避免数据不一致
  • 二级缓存:一级缓存设置过期时间,二级缓存永不过期,一级缓存过期的时候,去查二级缓存,并开启后台线程去查数据库,再更新两个缓存

缓存热点

原因:对于一些特别热点的数据,缓存的压力也会很大

解决办法:

  • 将缓存生成多个副本,放到多个缓存服务器上,有一个注意点,就是多个副本的过期时间控制在一个时间范围内,避免缓存同时失效的时候,引发缓存雪崩

转载于:https://www.cnblogs.com/yinchh/p/10434355.html

你可能感兴趣的文章
Eclipse相关集锦
查看>>
虚拟化架构中小型机构通用虚拟化架构
查看>>
继承条款effecitve c++ 条款41-45
查看>>
Java泛型的基本使用
查看>>
1076 Wifi密码 (15 分)
查看>>
noip模拟赛 党
查看>>
bzoj2038 [2009国家集训队]小Z的袜子(hose)
查看>>
Java反射机制及其Class类浅析
查看>>
Postman-----如何导入和导出
查看>>
移动设备显示尺寸大全 CSS3媒体查询
查看>>
图片等比例缩放及图片上下剧中
查看>>
【转载】Linux screen 命令详解
查看>>
background-clip,background-origin
查看>>
Android 高级UI设计笔记12:ImageSwitcher图片切换器
查看>>
【Linux】ping命令详解
查看>>
对团队成员公开感谢博客
查看>>
java学习第三天
查看>>
python目录
查看>>
django+uwsgi+nginx+sqlite3部署+screen
查看>>
Andriod小型管理系统(Activity,SQLite库操作,ListView操作)(源代码下载)
查看>>