1. Redis优点
- 使用内存进行存储效率高
- 使用单线程避免线程切换
- 底层有丰富的数据结构
- 支持持久化
2. Redis数据结构及其应用场景
- String 比如说可以用于点赞数
- List 比如说可以用户好友列表
- hash比如说可以用于存放商品的详细信息
- Set比如说可以用于共同关注的好友
- zSet比如说可以用于排行榜
3. Redis的过期删除策略有哪些
- 惰性删除:是在使用到key的时候判断是否过期了
- 定期删除: 每隔一段时间随机判断key是否过期了如果过期了就删除了
4. Redis的淘汰机制
- TTL:从设置过期时间的key中移除要过期的key
- Random:从设置过期时间的key随机移除一些
- LRU:移除最少使用的key
5. 常见的持久化机制有哪些,优缺点是啥
- AOF持久化:就是将所有的写操作以追加的方式追加到日志文件中
- 快照持久化:就是将某一个时间段的数据以快照的方式保存起来转为二进制
- 混合持久化:就是先将内存中的数据以RDB方式保存到AOF中,然后在追加未写入的AOF日志。
- AOF优点:安全性高日志可读性好
- AOF缺点:文件体积大恢复速度慢
- RDB优点:恢复速度快,但是可能会导致数据丢失。
- 混合持久化:恢复速度快,数据安全性。
6. 缓存击穿,缓存穿透,缓存雪崩的区别以及对应的解决方案
- 缓存击穿:就是在redis中不存在在数据库中存在,当大量的用户的访问同一个key的话那么所有请求就会落到数据库上导致数据库的压力倍增。
- 解决方法:
- 可以通过加锁当第一个请求来首先判断redis中是否存在,如果不存在就加锁,然后从数据库中将数据读取并保存到redis中后面的请求就会从redis中来获取key。
- 可以将key设置成永久的
- 或者设置自动续期。
- 缓存穿透:就是key不存在redis中也不存在数据库中比如说恶意攻击。
解决方法:就是将null值存储起来或者使用布隆过滤器 - 缓存雪崩:就是所有中的key同时全部过期了导致所有的key全部过期。
解决方案:将每个key设置一个不同过期时间