Redis 缓存问题及解决

所有问题解决的关键就是尽少的访问数据库,或者避免太集中的访问。

一,缓存穿透 (key在数据库不存在)


  • 当数据既不在缓存中,也不在数据库中,导致请求访问缓存没数据,访问数据库也没数据,即 每次都一穿到底。
  • 当有大量这样的请求到来时,数据库的压力骤增。

解决:

  1. 对请求过滤:参数检查、黑名单、白名单等,直接拒绝。
  2. 缓存空值:对查询不存在的数据也缓存下来(值为null),并设置较短过期时间。
  3. 使用布隆过滤器快速判断数据是否存在,避免通过查询数据库来判断(使用bitmaps实现):在写入数据库数据时,使用布隆过滤器做个标记,然后在用户请求发现缓存没有值时,查询布隆过滤器快速判断数据是否存在。

二,缓存击穿(热点key过期)


对于热点数据,当缓存失效的一瞬间,所有的请求都被下放到数据库去请求更新缓存,数据库被压垮。
解决:

  1. 访问数据库加分布式锁:获得锁的那个线程才能去访问数据库,并写回缓存,其他线程等待。
  2. 热点数据不过期:由后台异步更新缓存,或者在热点数据即将过期前,提前通知后台线程更新缓存以及重新设置过期时间。

三,缓存雪崩(大量key同时过期)


当大量缓存在同一时间过期,如果此时有大量的用户请求,瞬间所有的请求都被下放到数据库,数据库就崩掉了。
解决:

  1. 将缓存失效时间随机打散 在原有的失效时间基础上增加一个随机值(比如1到10分钟)这样每个缓存的过期时间都不重复了,也就降低了缓存集体失效的概率。
  2. 缓存设置为不过期 通过后台服务来更新缓存数据。
相关推荐
数智化管理手记8 分钟前
零基础认知精益生产——核心本质与必避误区
大数据·数据库·人工智能·低代码·制造
weixin_381288189 分钟前
MongoDB备节点无法读取数据怎么解决_rs.slaveOk()与Secondary读取权限
jvm·数据库·python
qq_6543669813 分钟前
Vue 3 中集成 Three.js 场景的完整实践指南
jvm·数据库·python
逻极17 分钟前
MySQL 从入门到精通:一个老 DBA 的实战心法
运维·数据库·mysql·从入门到精通·mysql从入门到精通
qq_4240985617 分钟前
JavaScript中箭头函数在类方法定义中的this绑定优势
jvm·数据库·python
2301_8038756120 分钟前
HTML怎么用Lawyer Zone对齐律所图_Lawyer专业主题图片布局
jvm·数据库·python
xuhaoyu_cpp_java24 分钟前
事务学习(一)
数据库·经验分享·笔记·学习·mysql
Polar__Star26 分钟前
golang如何实现Trie前缀树_golang Trie前缀树实现解析
jvm·数据库·python
weixin_4087177729 分钟前
SQL中JOIN不同存储引擎表的影响_索引兼容性与查询性能评估
jvm·数据库·python
qq_1898070330 分钟前
如何让导航栏的下落动画效果更慢?
jvm·数据库·python