redis面试题
一、Redis是什么?
二、Redis都有哪些使用场景?
三、 Redis有哪些功能(和二差不多)
四、Redis支持的数据类型有哪些?
五、Redis为什么是单线程的?
六、Redis真的是单线程的吗?
七、Redis持久化有几种方式?
八、什么是缓存穿透?怎么解决?
九、怎么保证缓存和数据库数据的一致性?
十、Redis,什么是缓存雪崩?怎么解决?
十一、Redis怎么实现分布式锁?
十二. redis在实现分布式锁式有什么缺陷
十三、Redis 淘汰策略有哪些?
一、Redis是什么?
redis是使用C语言编写的一个高速缓存数据,它以key-value形式存储数据,而且它支持的数据类型非常丰富。
二、Redis都有哪些使用场景?
1.热点数据的缓存
2. 排行榜
3.记录帖子的点赞数、点击数、评论数
4. 计时器
5. 实现分布式锁
6. 使用session的共享–后面项目时使用
三、 Redis有哪些功能(和二差不多)
四、Redis支持的数据类型有哪些?
- String
- Hash
- List
- Set
- ZSet
五、Redis为什么是单线程的?
因为Redis是基于内存的操作,CPU不是Redis的瓶颈,Redis的瓶颈最有可能是机器内存的大小或者网络带宽。既然单线程容易实现,而且CPU不会成为瓶颈,那就顺理成章地采用单线程的方案了
六、Redis真的是单线程的吗?
并不是真的单线程,比如:RDB—Bgsave时,创建一个子线程
七、Redis持久化有几种方式?
RDB(Redis Database):指定的时间间隔能对你的数据进行快照储存。
AOF(Append Only File):每一个收到的写命令,都通过writer函数追加到文件。
八、什么是缓存穿透?怎么解决?
缓存穿透:查询的数据在数据库中不存在,缓存中也不存在,这时有可能有人恶意访问这种数据。这些请求都会访问数据库,从而出现数据库压力过大。
情景:
1.比如id不合法
2.确实数据库中不存在。解决:
- 在controller加校验
- 我们可以在缓存中存入一个空对象,但是对象的过期时间不要太长,一般不会超过5分钟。
- 可以使用布隆过滤器。布隆过滤器里面只存id,过滤器会误判,漏掉1%的非法请求。
九、怎么保证缓存和数据库数据的一致性?
- 设置合理的过期时间
- 当执行增删改时,需要删除缓存数据
十、Redis,什么是缓存雪崩?怎么解决?
缓存雪崩:在某一时刻,出现大量数据过期,而这时就有大量的请求,访问该数据,这种现象叫做缓存雪崩。
什么情况下会出现大量数据过期:
- 项目刚刚上线
- redis服务器宕机
- 缓存数据真实过期
解决方案:
- 上线前预热数据。
- 集群
- 设置过期时间时要分散设置。
十一、Redis怎么实现分布式锁?
使用redis中的setnx命令–占锁,当业务代码执行完毕后,释放锁资源,而释放锁的命令是del。
十二. redis在实现分布式锁式有什么缺陷
超时问题: 业务代码执行时间超过锁时间。
解决: 使用:watchDog机制。 我们使用第三方:redisson
十三、Redis 淘汰策略有哪些?
- volatile-lru: 从已设置过期时间 的数据集 (server. db[i].expires)中挑选 最近最少使用的 数据淘汰。
- volatile-ttl: 从已设置过期时间 的数据集 (server. db[i].expires)中挑选 将要过期的 数据淘汰。
- volatile-random: 从已设置过期时间 的数据集 (server. db[i].expires)中任意选择 数据淘汰。
- allkeys-lru: 从数据集 (server. db[i]. dict) 中挑选 最近最少使用 的数据淘汰。
- allkeys-random: 从数据集 (server. db[i]. dict)中任意选择 数据淘汰。
- no-enviction (驱逐): 禁止驱逐数据。