Redis过期删除机制与内存淘汰策略的解析指南

 更新时间:2025年06月10日 15:30:12   作者:拾荒的小海螺  
在使用 Redis 构建缓存系统时,很多开发者只设置了 EXPIRE 但却忽略了背后 Redis 的过期删除机制与内存淘汰策略,下面小编就来和大家详细介绍一下

1、简述

在使用 Redis 构建缓存系统时,很多开发者只设置了 EXPIRE 但却忽略了背后 Redis 的过期删除机制与内存淘汰策略。理解这两者非常关键,直接关系到你的缓存系统是否高效、稳定、可控。

本文将深入剖析 Redis 中的两类机制:

  • 过期删除策略:key 如何在过期后被清除?
  • 内存淘汰策略:内存满了之后,哪些 key 会被删除?

2、Redis 的过期删除策略(Key Expiration)

Redis 支持给 key 设置 TTL(Time To Live),例如:

SET user:1:name "Tom" EX 60  # 设置60秒后过期

Redis 有三种过期删除策略:

策略名称触发方式特点与代价
惰性删除访问 key 时触发延迟释放内存,资源占用低,但可能滞留
定期删除每秒扫描过期 key有概率清理过期 key,减缓内存膨胀
主动删除内存不足时触发与内存淘汰策略结合,主动回收

Redis 实际如何执行过期?

Redis 并不会在 key 到期的一刻立刻删除它,而是:

  • 每秒随机抽取一批 key 检查过期(默认每次检查 20 个)
  • 被访问的 key 会“惰性检查”,若过期就顺便删掉
  • 在内存压力大时,会加速触发清理

3、Redis 内存淘汰策略(Eviction Policy)

当 Redis 达到最大内存上限(由 maxmemory 指定)时,就必须开始淘汰旧数据。此时就轮到 内存淘汰策略 发挥作用。

Redis 提供的 8 种淘汰策略:

策略描述
noeviction默认策略,拒绝写入新数据,直接报错
allkeys-lru所有 key 中,淘汰最近最少使用的
volatile-lru只在设置了 TTL 的 key 中,淘汰最少使用的
allkeys-random所有 key 中,随机淘汰
volatile-random只在设置了 TTL 的 key 中,随机淘汰
volatile-ttl只淘汰 TTL 最短的 key(最早过期)
volatile-lfu只在设置了 TTL 的 key 中,淘汰最少频率使用
allkeys-lfu所有 key 中,淘汰最少频率使用

配置示例:

maxmemory 512mb
maxmemory-policy allkeys-lru

4、实践场景与建议

场景 1:普通缓存场景(推荐)

maxmemory 1gb
maxmemory-policy allkeys-lru

优点:自动替换最不常访问的 key,效果最贴近缓存的预期行为

使用方式:

SET user:123 "json-data" EX 300

场景 2:数据较重要,只删除过期 key

maxmemory 1gb
maxmemory-policy volatile-lru

仅淘汰设置了过期时间的 key,持久 key 不被动清除

适合混合数据结构:部分缓存 + 部分持久值

场景 3:用户限流或验证码存储

SET captcha:uid123 "XYZ" EX 60

结合 volatile-ttl 策略,可以优先清理即将过期的验证码等

5、示例:模拟淘汰行为

# 配置
CONFIG SET maxmemory 100kb
CONFIG SET maxmemory-policy allkeys-lru

# 插入多个 key
for i in {1..100}; do
  SET "key$i" "$(openssl rand -hex 20)"
done

# 查看哪些 key 被淘汰了
INFO stats | grep evicted

输出示例:

evicted_keys:57

说明有 57 个 key 被自动淘汰,Redis 按 LRU 策略生效。

  • 附加建议
  • Redis 淘汰的是“key”,不是“内存最占用的值”
  • Redis 7.0+ 中 LFU 策略适合热点数据,尤其在流量分布极不均衡时更精准
  • 若你使用 Redis 作为数据库(而非缓存),应避免使用淘汰策略,并开启持久化

6、总结

分类策略类型控制方式推荐场景
过期删除策略惰性/定期自动所有 Redis 使用
内存淘汰策略8 种策略配置项控制缓存系统、高频数据

推荐配置模板

# 设置最大内存限制
maxmemory 512mb

# 设置淘汰策略
maxmemory-policy allkeys-lru

到此这篇关于Redis过期删除机制与内存淘汰策略的解析指南的文章就介绍到这了,更多相关Redis过期删除与内存淘汰内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 解决 Redis 数据倾斜、热点等问题

    解决 Redis 数据倾斜、热点等问题

     单台机器的硬件配置有上限制约,一般我们会采用分布式架构将多台机器组成一个集群,这篇文章主要介绍了解决 Redis 数据倾斜、热点等问题,需要的朋友可以参考下
    2022-12-12
  • 在Ubuntu 14.04系统上备份和恢复Redis数据详细步骤

    在Ubuntu 14.04系统上备份和恢复Redis数据详细步骤

    这篇文章主要给大家介绍了关于在Ubuntu 14.04系统上备份和恢复Redis数据的详细步骤,文中通过代码介绍的非常详细,对大家学习或者使用Redis具有一定的参考借鉴价值,需要的朋友可以参考下
    2024-04-04
  • RedisTemplate 实现基于Value 操作的简易锁机制(示例代码)

    RedisTemplate 实现基于Value 操作的简易锁机制(示例代码)

    本文将介绍如何使用 RedisTemplate 的 opsForValue().setIfAbsent() 方法来实现一种简单的锁机制,并提供一个示例代码,展示如何在 Java 应用中利用这一机制来保护共享资源的访问,感兴趣的朋友跟随小编一起看看吧
    2024-05-05
  • 通过 Redis 实现 RPC 远程方法调用(支持多种编程语言)

    通过 Redis 实现 RPC 远程方法调用(支持多种编程语言)

    这篇文章主要介绍了通过 Redis 实现 RPC 远程方法调用,支持多种编程语言,本文就以Ruby和Python为例,给出了实现代码,需要的朋友可以参考下
    2014-09-09
  • Redis集群设置密码访问的实现

    Redis集群设置密码访问的实现

    本文档介绍了在Redis集群上配置和管理密码,包括为每个节点添加requirepass配置以启用密码保护,及通过redis-cli关闭集群时使用密码,感兴趣的可以了解一下
    2025-08-08
  • Spring Boot 整合Redis 实现优惠卷秒杀 一人一单功能

    Spring Boot 整合Redis 实现优惠卷秒杀 一人一单功能

    这篇文章主要介绍了Spring Boot 整合Redis 实现优惠卷秒杀 一人一单,在分布式系统下,高并发的场景下,会出现此类库存超卖问题,本篇文章介绍了采用乐观锁来解决,需要的朋友可以参考下
    2022-09-09
  • React中immutable的使用

    React中immutable的使用

    这篇文章主要介绍了React中immutable的使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-04-04
  • Redis increment 函数处理并发序列号案例

    Redis increment 函数处理并发序列号案例

    这篇文章主要介绍了Redis increment 函数处理并发序列号案例,本文通过实例代码给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧
    2024-08-08
  • Redis慢查询日志及慢查询分析详解

    Redis慢查询日志及慢查询分析详解

    这篇文章主要为大家介绍了Redis慢查询日志及慢查询分析详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-01-01
  • 一文详解Redis在Ubuntu系统上的安装步骤

    一文详解Redis在Ubuntu系统上的安装步骤

    安装redis在Ubuntu上有多种方法,下面这篇文章主要给大家介绍了关于Redis在Ubuntu系统上安装的相关资料,文中通过图文以及代码介绍的非常详细,需要的朋友可以参考下
    2024-07-07

最新评论