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

2025-06-11 04:50

本文主要是介绍Redis过期删除机制与内存淘汰策略的解析指南,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

《Redis过期删除机制与内存淘汰策略的解析指南》在使用Redis构建缓存系统时,很多开发者只设置了EXPIRE但却忽略了背后Redis的过期删除机制与内存淘汰策略,下面小编就来和大家详细介绍一下...

1、简述

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

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

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

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
js

场景 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 被淘汰android了
INFO stats | grep evicted

输出示例:

evicted_keys:57

说明有 57 http://www.chinasem.cn个 key 被自动淘汰,Redis 按 LRU 策略生效。

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

6、总结

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

推荐配置模板

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

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

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

这篇关于Redis过期删除机制与内存淘汰策略的解析指南的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1155000

相关文章

Redis 的 SUBSCRIBE命令详解

《Redis的SUBSCRIBE命令详解》Redis的SUBSCRIBE命令用于订阅一个或多个频道,以便接收发送到这些频道的消息,本文给大家介绍Redis的SUBSCRIBE命令,感兴趣的朋友跟随... 目录基本语法工作原理示例消息格式相关命令python 示例Redis 的 SUBSCRIBE 命令用于订

JavaScript中的高级调试方法全攻略指南

《JavaScript中的高级调试方法全攻略指南》什么是高级JavaScript调试技巧,它比console.log有何优势,如何使用断点调试定位问题,通过本文,我们将深入解答这些问题,带您从理论到实... 目录观点与案例结合观点1观点2观点3观点4观点5高级调试技巧详解实战案例断点调试:定位变量错误性能分

Java使用jar命令配置服务器端口的完整指南

《Java使用jar命令配置服务器端口的完整指南》本文将详细介绍如何使用java-jar命令启动应用,并重点讲解如何配置服务器端口,同时提供一个实用的Web工具来简化这一过程,希望对大家有所帮助... 目录1. Java Jar文件简介1.1 什么是Jar文件1.2 创建可执行Jar文件2. 使用java

Python实现精确小数计算的完全指南

《Python实现精确小数计算的完全指南》在金融计算、科学实验和工程领域,浮点数精度问题一直是开发者面临的重大挑战,本文将深入解析Python精确小数计算技术体系,感兴趣的小伙伴可以了解一下... 目录引言:小数精度问题的核心挑战一、浮点数精度问题分析1.1 浮点数精度陷阱1.2 浮点数误差来源二、基础解决

Java实现在Word文档中添加文本水印和图片水印的操作指南

《Java实现在Word文档中添加文本水印和图片水印的操作指南》在当今数字时代,文档的自动化处理与安全防护变得尤为重要,无论是为了保护版权、推广品牌,还是为了在文档中加入特定的标识,为Word文档添加... 目录引言Spire.Doc for Java:高效Word文档处理的利器代码实战:使用Java为Wo

深度解析Python中递归下降解析器的原理与实现

《深度解析Python中递归下降解析器的原理与实现》在编译器设计、配置文件处理和数据转换领域,递归下降解析器是最常用且最直观的解析技术,本文将详细介绍递归下降解析器的原理与实现,感兴趣的小伙伴可以跟随... 目录引言:解析器的核心价值一、递归下降解析器基础1.1 核心概念解析1.2 基本架构二、简单算术表达

从入门到精通详解Python虚拟环境完全指南

《从入门到精通详解Python虚拟环境完全指南》Python虚拟环境是一个独立的Python运行环境,它允许你为不同的项目创建隔离的Python环境,下面小编就来和大家详细介绍一下吧... 目录什么是python虚拟环境一、使用venv创建和管理虚拟环境1.1 创建虚拟环境1.2 激活虚拟环境1.3 验证虚

深度解析Java @Serial 注解及常见错误案例

《深度解析Java@Serial注解及常见错误案例》Java14引入@Serial注解,用于编译时校验序列化成员,替代传统方式解决运行时错误,适用于Serializable类的方法/字段,需注意签... 目录Java @Serial 注解深度解析1. 注解本质2. 核心作用(1) 主要用途(2) 适用位置3

sky-take-out项目中Redis的使用示例详解

《sky-take-out项目中Redis的使用示例详解》SpringCache是Spring的缓存抽象层,通过注解简化缓存管理,支持Redis等提供者,适用于方法结果缓存、更新和删除操作,但无法实现... 目录Spring Cache主要特性核心注解1.@Cacheable2.@CachePut3.@Ca

Java MCP 的鉴权深度解析

《JavaMCP的鉴权深度解析》文章介绍JavaMCP鉴权的实现方式,指出客户端可通过queryString、header或env传递鉴权信息,服务器端支持工具单独鉴权、过滤器集中鉴权及启动时鉴权... 目录一、MCP Client 侧(负责传递,比较简单)(1)常见的 mcpServers json 配置