redis常见面试题
1、redis是单线程
你好! 这是你第一次使用 Markdown编辑器 所展示的欢迎页。如果你想学习如何使用Markdown编辑器, 可以仔细阅读这篇文章,了解一下Markdown的基本语法知识。
2、缓存击穿、缓存穿透、缓存雪崩你了解吗
缓存击穿:指的是数据库中有数据 ,缓存中没有数据,由于并发多,同一时间访问数据库,对数据库造成了压力
- 对于热点数据可以设置相对应的永不过期
- 可以使用互斥锁mutex key,最简单的流程为,先从redis获取数据,获取不到,则从redis中根据key获取锁,获取不到锁,则等待,获取到锁,则进行数据库查询,写入缓存
缓存穿透:用户请求获取缓存和数据库中都没有的数据,比如id=uuid等,这时会对数据库造成压力
解决方案:
- 对接口层增加校验,如用户鉴权校验,使用断言对必要的条件进行非空判断,好比id的长度必须大于0等
- 对于数据库中没有的数据,也可以添加缓存,对应key添加null,设置失效时间比较短即可好比30s,这样可以防止攻击者用同一个id频繁访问
缓存雪崩:通俗的讲,是指缓存设置的失效时间相同或者redis服务器宕机等原因,造成了缓存失效,而大量的访问数据库,对数据库造成了压力