# Redis的过期策略以及内存淘汰机制

# 过期策略

Redis 采用的是定期删除+懒汉式删除策略。

定期删除,Redis 默认每隔 100ms 检查,是否有过期的 Key,有过期 Key 则删除(类似小顶堆实现)

惰性删除,获取某个 Key 的时候,Redis 会检查一下,这个 Key 如果设置了过期时间,如果过期了此时就会删除。

# 内存淘汰机制

如果没有过期的Key被定期删除或者懒汉式删除,内存不断增长,怎么办?

在 redis.conf 中有一行配置:

# maxmemory-policy volatile-lru
1

六种内存淘汰策略:

  • noeviction:当内存不足以容纳新写入数据时,新写入操作会报错。应该没人用吧。
  • allkeys-lru:当内存不足以容纳新写入数据时,在键空间中,移除最近最少使用的 Key。推荐使用,目前项目在用这种。
  • allkeys-random:当内存不足以容纳新写入数据时,在键空间中,随机移除某个 Key。应该也没人用吧,你不删最少使用 Key,去随机删。
  • volatile-lru:当内存不足以容纳新写入数据时,在设置了过期时间的键空间中,移除最近最少使用的 Key。这种情况一般是把 Redis 既当缓存,又做持久化存储的时候才用。不推荐。
  • volatile-random:当内存不足以容纳新写入数据时,在设置了过期时间的键空间中,随机移除某个 Key。依然不推荐。
  • volatile-ttl:当内存不足以容纳新写入数据时,在设置了过期时间的键空间中,有更早过期时间的 Key 优先移除。不推荐。

推荐使用:allkeys-lru