Redis使用场景
缓存穿透
缓存穿透:查询一个不存在的数据,mysql查询不到数据也不会直接写入缓存,就会导致每次请求都查数据库。
解决方案一:缓存空数据
解决方案二:布隆过滤器
缓存击穿
缓存击穿:给某一个Key设置了过期时间,当Key过期的时候,恰好这时间点对这个Key有大量的并发请求过来,这些并发的请求可能会瞬间把DB压垮
互斥锁:强一致,性能差
逻辑过期:高可用,性能优,不能保证数据绝对一致
缓存雪崩
缓存雪崩:指在同一时段大量的缓存Key同时失效或者Redis服务宕机,导致大量请求到达数据库,带来巨大压力
Redis宕机:
持久化
两种数据持久化的方式:
1.RDB
2.AOF
RDB
主动备份:
save 指令 由Redis主进程来执行RDB,会阻塞所有命令
bgsave 开启子进程执行RDB,避免主进程受到影响
Redis内部也有出发RDB的机制,可以在redis.conf文件中找到
AOF
RDB与AOF对比