Redis

缓存穿透

查询一个不存在的数据 可以使用布隆过滤器解决

布隆过滤器

使用redession实现 通过三次hash计算来把数据库的下标改成1 使误判率达到5%以下

缓存击穿

对于设置了过期时间的key 在某个时间点过期 正好有大量的并发请求 这个时候大量的并发请求发现缓存过期以后 一般从后端数据库大量加载数据设回缓存 大量请求可能会把数据库压垮

解决缓存击穿可以设置互斥锁或者逻辑过期

互斥锁

缓存失效的时候 不会立即去加载数据库的内容

先用Redis里边的setnx去设置一个互斥锁 当操作成功返回的时候再进行加载数据库并设置缓存

否则重试get缓存的方法

设置key逻辑过期

不设置过期时间 而是在存入key的时候设置一个过期字段 查询的时候从redis取出数据先判断字段是否过期 如果过期 开通另一个线程进行数据同步 当前线程正常返回数据但是这个数据也不是最新数据

选互斥锁还是逻辑过期解决

互斥锁适合强一致性

逻辑过期适合高可用性 性能高

缓存雪崩

设置缓存的时候采用了相同的过期时间 导致缓存在某一时刻同时失效请求全部转发到DB DB瞬时压力过大雪崩 缓存击穿时 击穿某一个key缓存 而缓存雪崩时多个key同时过期

解决缓存雪崩

在原有的设置缓存过期时间的基础上再加一个随机函数 这样每个key的过期时间重复率会降低 很难引发集体失效的情况了

相关推荐
TH_12 分钟前
6、前台界面传递老数据,导致业务数据错误
数据库
光影少年27 分钟前
PostgreSQL数据库学习路线
数据库·学习·postgresql
哈哈老师啊34 分钟前
Springboot简单二手车网站qs5ed(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
数据库·spring boot·后端
JIngJaneIL38 分钟前
基于Java+ vue图书管理系统(源码+数据库+文档)
java·开发语言·前端·数据库·vue.js·spring boot·后端
VX:Fegn08951 小时前
计算机毕业设计|基于springboot + vue考勤管理系统(源码+数据库+文档)
数据库·vue.js·spring boot·后端·课程设计
晚风_END1 小时前
postgresql数据库|数据库维护系列|postgresql数据库参数配置详解和数据库维护时机的选择(三)
运维·开发语言·数据库·postgresql·oracle
一 乐1 小时前
幼儿园管理|基于springboot + vue幼儿园管理系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·后端
JIngJaneIL1 小时前
基于Java + vue校园论坛系统(源码+数据库+文档)
java·开发语言·前端·数据库·vue.js·spring boot·后端
期待のcode1 小时前
Springboot多数据源配置
java·数据库·spring boot·后端·mybatis
Knight_AL1 小时前
深入解析 Spring 循环依赖:如何通过三级缓存解决 A ↔ B 的依赖问题
java·spring·缓存