news 2026/5/6 7:34:30

Redis 的内存回收机制详解

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Redis 的内存回收机制详解

Redis 的内存回收机制详解

Redis 是基于内存的高性能数据库,但内存资源有限。当单节点内存过大时,不仅会增加成本,还可能影响RDB/AOF 持久化主从同步的性能与稳定性。

为此,Redis 提供了完善的内存管理机制,主要包括两类策略:

  • 过期策略(Expiration Policy):自动清理设置了 TTL 的过期数据
  • 淘汰策略(Eviction Policy):在内存达到上限时,主动移除部分数据以腾出空间

一、内存上限配置

通过redis.conf设置最大内存限制:

maxmemory 1gb

💡 若未设置,32 位系统默认为 3GB,64 位系统默认无限制(直到耗尽物理内存)。

当内存使用达到maxmemory时,Redis 将根据maxmemory-policy配置的策略决定如何处理新写入请求。


二、过期策略(针对带 TTL 的 Key)

Redis 允许为每个 key 设置生存时间(TTL, Time To Live),到期后自动失效。

1. 设置 TTL 的方式

# 方式1:先 set,再 expireSET k1 value1 EXPIRE k120# 20 秒后过期# 方式2:set 时直接指定(推荐)SET k1 value1 EX20# EX = seconds

支持单位:EX(秒)、PX(毫秒)、EXAT(绝对 Unix 时间戳)、PXAT等。

2. 过期判断机制

Redis 内部维护一个过期字典(expires dict),以 key 为键、过期时间为值。通过比对当前时间与过期时间,判断 key 是否失效。

3. 过期 key 的删除策略

Redis 采用惰性删除 + 定期删除相结合的方式,平衡 CPU 与内存开销:

✅ 惰性删除(Lazy Expiration)
  • 触发时机:当客户端访问某个 key 时
  • 行为:先检查是否过期,若过期则删除并返回nil
  • 优点:CPU 友好
  • 缺点:过期 key 可能长期驻留内存
✅ 定期删除(Active Expiration)
  • 触发频率:每秒执行10 次
  • 过程
    1. 随机抽取20 个带 TTL 的 key
    2. 删除其中已过期的 key
    3. 若过期 key 比例> 25%,则立即开启下一轮扫描(最多 25 轮/秒)
  • 目的:防止大量过期 key 积压,导致内存浪费

📌 两者互补:惰性保证最终一致性,定期控制内存水位。


三、内存淘汰策略(Eviction Policy)

即使所有 key 都未过期,内存仍可能被占满。此时,Redis 会根据maxmemory-policy配置主动淘汰数据。

1. 配置方式

maxmemory-policy allkeys-lru

2. 淘汰策略详解

策略作用范围淘汰依据适用场景
noeviction不淘汰,写入报错(error) OOM默认策略,适用于不允许丢失数据的场景
volatile-ttl仅带 TTL 的 key剩余存活时间最短(最先过期)缓存类数据,希望优先删快过期的
volatile-random仅带 TTL 的 key随机删除简单场景,无明确访问模式
volatile-lru仅带 TTL 的 keyLRU(最近最少使用)带 TTL 的热点缓存
volatile-lfu仅带 TTL 的 keyLFU(最少频繁使用)Redis 4.0+,识别长期低频访问
allkeys-random所有 key随机删除key 访问均匀,无热点
allkeys-lru所有 keyLRU(最近最少使用)最常用,通用缓存场景
allkeys-lfu所有 keyLFU(最少频繁使用)Redis 4.0+,识别冷数据

🔑LRU vs LFU

  • LRU(Least Recently Used):最近没用过的优先淘汰
  • LFU(Least Frequently Used):历史上使用频率最低的优先淘汰(更抗突发流量)

四、最佳实践建议

  1. 合理设置maxmemory:建议预留 20%~30% 内存给操作系统和其他进程
  2. 优先使用allkeys-lruallkeys-lfu:适用于大多数缓存场景
  3. 避免依赖noeviction:除非业务强要求“写入必须成功”
  4. 监控内存使用:通过INFO memory查看used_memoryevicted_keys等指标
  5. TTL + 淘汰策略结合使用:双重保障内存可控

总结
Redis 通过过期策略清理“时间到期”的数据,通过淘汰策略应对“内存不足”的压力。二者协同工作,既保证了高性能,又实现了内存的自动回收与管理。

📌 提示:淘汰策略不会触发持久化,被删除的数据将永久丢失,请根据业务容忍度选择合适策略。


作者:不会写程序的未来程序员
首发于 CSDN
版权声明:本文为原创文章,转载请注明出处。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/5 18:54:20

Tabula终极指南:快速从PDF提取表格数据的完整教程

Tabula终极指南:快速从PDF提取表格数据的完整教程 【免费下载链接】tabula Tabula is a tool for liberating data tables trapped inside PDF files 项目地址: https://gitcode.com/gh_mirrors/ta/tabula Tabula是一款革命性的开源工具,专门用于…

作者头像 李华
网站建设 2026/5/3 8:14:31

xv6 文件系统

1. xv6 文件系统的整体结构:目录是一棵树xv6 的文件系统中:文件 字节数组(例如普通文件)目录 一种特殊的文件,里面存的不是内容,而是:文件名 → inode 号(指向文件的引用&#xff…

作者头像 李华
网站建设 2026/5/6 3:21:35

MetaMCP终极指南:一站式管理所有MCP服务器的完整解决方案

在当今AI工具爆炸式增长的时代,开发者们面临着管理多个MCP(Model Context Protocol)服务器的挑战。每个项目可能使用不同的MCP服务器,工具配置繁琐,资源管理分散,这些问题严重影响了开发效率。MetaMCP应运而…

作者头像 李华
网站建设 2026/5/4 1:36:54

技术拆解:1688 API 接口开发全流程与商品数据抓取方案

1688 作为阿里巴巴旗下的批发电商平台,其开放的 API 接口为开发者提供了合规获取商品数据、商家信息的渠道。本文将从 API 接入准备、接口调用开发、数据抓取与解析等维度,完整拆解 1688 API 接口开发全流程,并结合实战代码实现商品数据抓取&…

作者头像 李华