Redis的过期策略和内存淘汰机制

大家都知道,redis是基于内存来存储数据的,但是内存资源是有限的,我们需要时刻考虑redis的内存容量。在实际工作过程当中,我们需要清楚redis的过期策略和内存淘汰机制。

一、redis的过期策略

定期删除:定期(100ms)从所有key中随机选择一些进行删除;

惰性删除:在我们获取key的时候,先检查key的过期时间,如果过期,便进行闪出去;

通过上面这两种方式,依旧会存在一些key,过期之后还会存在内存中,怎么办?使用内存淘汰机制!

二、redis的内存淘汰机制

noeviction: 默认淘汰策略(从redis的配置文件中可以看出),当我们向redis中写入数据的时候,如果内存不足,会直接报错;
allkeys-lru:当内存不足的时候,移除最近最少使用的key(常用的淘汰策略);
allkeys-random:当内存不足的时候,随机移除key;
volatile-lru:当内存不足的时候,在设置了过期时间的所有key中,移除最近最少使用的key;
volatile-random:当内存不足的时候,在设置了过期时间的所有key中,随机移除key;
volatile-ttl:当内存不足的时候,在设置了过期时间的所有key中,优先删除有更早过期时间的key;

你可能感兴趣的:(缓存和消息)