一、Redis 过期策略是什么?
就是:Redis 怎么处理已经过期的 key?什么时候删?
Redis 用 3 种策略组合 来清理过期 key:
- 惰性删除(你访问 key 时才删)
- 定期删除(后台定时抽查删)
- 内存淘汰机制(内存满了自动删)
二、3 种过期策略详解(超级通俗)
1)惰性删除(Lazy Expiration)
你访问 key 的时候,Redis 先看一眼:过期了没?
- 过期 → 直接删掉,返回不存在
- 没过期 → 正常返回
优点 :不浪费 CPU缺点:如果 key 一直不访问,会一直占内存
2)定期删除(Regular Expiration)
Redis 后台每隔 100ms 自动抽查一部分 key:
- 随机抽 20 个
- 把过期的删掉
- 如果删掉的比例超过 1/4,继续抽
优点 :控制内存不会爆缺点:不能保证所有过期 key 立刻被删
3)内存淘汰策略(Eviction)
当 Redis 内存满了,自动删 key 腾出空间。
常见策略:
volatile-lru:删除过期 的 key 中最少使用的allkeys-lru:删除所有 key 中最少使用的volatile-ttl:删除最快要过期的noeviction:不删,直接报错(默认)
三、Redis 过期策略 底层怎么实现?
需要记住 3 个核心点:
1. 每个 key 都存了过期时间
Redis 用一个 字典(expires 字典) 保存所有 key 的过期时间戳。
结构:
key → 过期时间戳
2. 惰性删除实现
if 访问key → 检查是否在 expires 字典里
if 已过期 → 删除key,返回null
3. 定期删除实现
Redis 源码里的定期清理逻辑:
for (i = 0; i < 循环次数; i++) {
随机抽取 20 个 key
删除其中过期的
if (删除数量 > 5 个) 继续抽
}