Redis过期策略

一、Redis 过期策略是什么?

就是:Redis 怎么处理已经过期的 key?什么时候删?

Redis 用 3 种策略组合 来清理过期 key:

  1. 惰性删除(你访问 key 时才删)
  2. 定期删除(后台定时抽查删)
  3. 内存淘汰机制(内存满了自动删)

二、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 个) 继续抽
}
相关推荐
cfm_29147 小时前
Redis缓存规范设计与全方位性能优化实战
redis·缓存·性能优化
weelinking7 小时前
【产品】12_接入数据库——让数据永久保存
jvm·数据库·python·react.js·数据挖掘·前端框架·产品经理
稳联技术老娜7 小时前
DeviceNet主站怎么连接西门子PLC,Profinet网关配置手册(那智机器人)
服务器·网络·数据库
这个DBA有点耶7 小时前
云上运维新挑战:当数据库不再“看得见摸得着”
数据库·sql·程序人生·云原生·运维开发·学习方法·dba
AskHarries9 小时前
系统提示词、开发者指令和用户输入的优先级
java·前端·数据库
消失在人海中9 小时前
oracle 数据库多表关联查询
服务器·数据库·oracle
九皇叔叔9 小时前
PostgreSQL/openGauss pg_stats 视图从入门到精通:统计信息、执行计划与慢 SQL 优化实战
数据库·sql·postgresql
南极企鹅10 小时前
MySQL间隙锁&临键锁
数据库·sql·mysql
TDengine (老段)11 小时前
TDengine 压缩编码机制 — 双层压缩架构与类型特化算法
大数据·数据库·物联网·算法·时序数据库·tdengine·涛思数据
苏渡苇12 小时前
Redis 持久化——RDB 快照 vs AOF 日志
数据库·redis·缓存·redis持久化·aof vs rdb