一.题目介绍
1.题目来源
实际面试中遇到,形式的话有书面解答也有口述。一般侧重点为Redis的应用,Redis的持久化有哪些,Redis的淘汰策略
2.题目
1)Redis在你的系统里扮演一个什么样的角色?
2)Redis的持久化有哪些?
3)Redis的淘汰策略
二.具体解答
1.Redis在你的系统里扮演一个什么样的角色?
1)缓存:Redis一般做缓存多一点,比如缓存临时的Token,或者不需要入库的临时数据
2)简单的发布订阅:Redis是支持发布与订阅功能的,所以在不想使用MQ的时候,Redis也能做发布与订阅的功能
3)简单的秒杀功能:秒杀一般需要预存数据和预扣库存,所以在秒杀开始之前库存数据应该存到Redis里,有购买时从Redis里读取库存,然后再更新到数据里
4)排名:Redis的zset数据类型合适做排名,这个在前面的文章里有提到过,感兴趣的可以去看看
2.Redis的持久化有哪些?
RDB:
RDB持久化是指在指定的时间间隔内将内存中的数据和操作通过快照的方式保存到redis bin目录下的一个默认名为 dump.rdb的文件,可以通过配置设置自动的快照持久化的方式,我们可以配置redis在n秒内进行快照的时间,如果超过这个时间节点,将会自动执行快照操作。虽然这种方式方便快捷,但是无法保证数据的绝对安全可靠,如果服务器在非备份时间跨度内发生了故障,无法做到对当前状态的实时保存,导致数据丢失。而且每次保存 RDB文件时, Redis都需要fork()出一个子进程,由子进程来执行具体的持久化工作,对资源消耗较大。
AOF: redis 的 AOF 持久化是在每次接受到的命令通过 write函数追加到文件中(默认是 appendonly.aof),但是由于操作系统在写入文件时使用了缓存来提高写入效率,还是可能会出现因服务器突然故障而导致的数据丢失,故我们可以通过配置文件告诉redis我们同步数据的时间间隔(默认间隔是每秒同步一次)
3.Redis的淘汰策略
一般说的是指Redis内存淘汰机制,大致有以下几类:
1)LRU:LRU是Least recently used,最近最少使用的意思,简单的理解就是从数据库中删除最近最少访问的数据,该算法认为,你长期不用的数据,那么被再次访问的概率也就很小了,淘汰的数据为最长时间没有被使用,仅与时间相关。
2)LFU:LFU是Least Frequently Used,最不经常使用的意思,简单的理解就是淘汰一段时间内,使用次数最少的数据,这个与频次和时间相关。
3)TTL:Redis中,有的数据是设置了过期时间的,而设置了过期时间的这部分数据,就是该算法要解决的对象。如果你快过期了,不好意思,我内存现在不够了,反正你也要退休了,提前送你一程,把你干掉吧。
4)随机淘汰:随机性的淘汰,无规律
三.题后思考
关于Redis还有深入的问题是它为什么这么快?它的底层使用了什么使得它存取数据这么快?还有就是针对情况不同选择其持久性类型,这些都是值得深入思考的问题。