Redis面试考点

Redis使用场景

看你的项目使用了redis吗,项目中在哪些场景使用了redis?

1.缓存存在的面试题:缓存三兄弟(缓存穿透、缓存击穿、缓存雪崩)双写一致、持久化、数据过期、淘汰策略
2.分布式锁存在的面试题:setnx redisson

缓存穿透

什么是缓存穿透?怎么解决?
当一个请求进来时,查询的一个不存在的数据。会先进入redis进行查询。如果redis也查不到则会查询DB。DB也查不到数据不会直接写缓存。就会导致每次请求都查询DB

解决方案一:缓存空数据,查询返回的数据为空,仍把这个空结果进行缓存
优点:简单
缺点:浪费内存资源
在这里插入图片描述
解决方案二:布隆过滤器
优点:内存占用少,没有多余key
缺点:实现复杂,存在误判
在这里插入图片描述

缓存击穿

什么是缓存击穿?怎么解决?
当某个key设置了过期时间,当key过期的时候,恰好这时间点对这个key有大量的并发请求过来,这些并发的请求可能会瞬间把DB压垮。
在这里插入图片描述
解决方案一:互斥锁
优点:强一致
缺点:性能差
在这里插入图片描述
解决方案二:逻辑过期
优点:高可用,性能优
缺点:不能保证数据绝对一致
在这里插入图片描述

缓存雪崩

什么是缓存雪崩?怎么解决?
在同一时间段大量的缓存key同时失效或者Redis服务宕机,导致大量请求到达DB,带来巨大压力
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值