一、过期策略
1. 定期删除
redis 默认是每隔 100ms 就随机抽取一些设置了过期时间的 key,检查其是否过期,如果过期就删除。
之所以是随机抽取,是为了避免Key过多,如果全量检查,会影响性能。redis不可能说扫描所有的key去检查过期时间。
2. 惰性删除。
基于第一点,因为只抽取了部分,就会存在很多过期了没有删除的Key,所以当你查询到对应的Key的时候,
就会先检查是否过期,如果过期了就进行删除,然后不返回数据。
二、内存淘汰机制
即使有着过期策略,redis内存仍然可能不够用,这个时候就需要一个兜底措施来保证redis的内存够用。
这个措施就是淘汰机制。
redis 内存淘汰机制有以下几个:(以下策略都是内存不足以写入新数据的时候会触发)
- noeviction: 新写入操作会报错,这个一般没人用吧,实在是太恶心了。
- allkeys-lru:在键空间中,移除最近最少使用的 key(这个是最常用的)。
- allkeys-random:在键空间中,随机移除某个 key,这个一般没人用吧,为啥要随机,肯定是把最近最少使用的 key 给干掉啊。
- volatile-lru:在设置了过期时间的键空间中,移除最近最少使用的 key(这个一般不太合适)。
- volatile-random:在设置了过期时间的键空间中,随机移除某个 key。
- volatile-ttl:在设置了过期时间的键空间中,有更早过期时间的 key 优先移除。