0

0

Redis怎样在内存告急时手动批量清理冷数据

P粉602998670

P粉602998670

发布时间:2026-03-19 09:25:02

|

281人浏览过

|

来源于php中文网

原创

Redis无冷数据识别能力,需人工定义冷标准(如IDLETIME≥86400)、定位冷键(SCAN+业务前缀,禁用KEYS)、安全删除(UNLINK分批,禁用FLUSH);maxmemory-policy仅兜底,删后须查mem_fragmentation_ratio。

redis怎样在内存告急时手动批量清理冷数据

直接说结论:Redis 本身没有“冷数据识别”能力,所谓手动批量清理冷数据,本质是“你定义冷、你找冷键、你删冷键”——三步缺一不可,漏掉任何一步都可能误删热数据或卡死服务。

怎么定义“冷数据”?别信直觉,得靠真实访问痕迹

Redis 不记录访问时间戳,TTL 只管过期不管冷热。OBJECT IDLETIME key 是唯一能查“多久没被访问过”的命令,但它有严重限制:只对未设置 EXPIRE 的 key 有效;且返回值是近似值(精度受 hz 配置影响),不是精确秒数。

  • 生产环境建议阈值设为 ≥ 86400(24 小时),避免把刚缓存的中间态数据误判为冷数据
  • 不要用 KEYS * 扫全库查 IDLETIME——会阻塞主线程,尤其在大实例上可能超时甚至触发 failover
  • 正确做法是结合业务日志或监控(如慢查询、AOF rewrite 频次)圈定疑似冷数据的 key 前缀,再针对性扫描

怎么安全批量删?UNLINK 比 DEL 更靠谱

DEL 是同步删除,遇到大 value(比如 10MB 的 hash)会卡住 Redis 主线程几百毫秒;UNLINK 把实际内存释放交给后台线程,主线程只做 key 标记,响应几乎无感。

MedPeer自然科学基金
MedPeer自然科学基金

科研申报与成果分析的智能数据引擎

下载
  • 单删:用 UNLINK key 替代 DEL key
  • 批量删(推荐):SCAN 分批 + UNLINK 管道,例如一次扫 1000 个 key:
    redis-cli --scan --pattern "cache:order:*" | xargs -n 1000 redis-cli unlink
  • 绝对不用 FLUSHDBFLUSHALL——它们不区分冷热,清的是整个库,等同于重启缓存,后端必然雪崩

为什么不能只靠 maxmemory-policy 自动淘汰?

maxmemory-policy(比如 allkeys-lru)只在内存真正打满时才触发,而“内存告急”往往发生在达到阈值前:比如从 70% 突增到 95%,但还没触发淘汰,此时写入变慢、延迟飙升,必须人工干预。

  • volatile-lru 类策略只淘汰带过期时间的 key,如果冷数据没设 TTL,它永远不碰
  • LRU/LFU 依赖访问频率统计,冷数据若长期没被访问,其 LRU clock 值可能已老化,反而不如新写入的热数据“优先级低”
  • 自动策略是兜底,不是主动治理——就像消防栓不能代替定期清理易燃物

最常被忽略的一点:删完冷数据后,务必用 INFO memorymem_fragmentation_ratio。如果这个值 > 1.5,说明内存碎片高,光删 key 不解决根本问题,得考虑重启实例或启用 activedefrag yes(但后者有 CPU 开销)。

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
c++中volatile关键字的作用
c++中volatile关键字的作用

本专题整合了c++中volatile关键字的相关内容,阅读专题下面的文章了解更多详细内容。

77

2025.10.23

线程和进程的区别
线程和进程的区别

线程和进程的区别:线程是进程的一部分,用于实现并发和并行操作,而线程共享进程的资源,通信更方便快捷,切换开销较小。本专题为大家提供线程和进程区别相关的各种文章、以及下载和课程。

806

2023.08.10

线程和进程的区别
线程和进程的区别

线程和进程的区别:线程是进程的一部分,用于实现并发和并行操作,而线程共享进程的资源,通信更方便快捷,切换开销较小。本专题为大家提供线程和进程区别相关的各种文章、以及下载和课程。

806

2023.08.10

常用的数据库软件
常用的数据库软件

常用的数据库软件有MySQL、Oracle、SQL Server、PostgreSQL、MongoDB、Redis、Cassandra、Hadoop、Spark和Amazon DynamoDB。更多关于数据库软件的内容详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1011

2023.11.02

内存数据库有哪些
内存数据库有哪些

内存数据库有Redis、Memcached、Apache Ignite、VoltDB、TimesTen、H2 Database、Aerospike、Oracle TimesTen In-Memory Database、SAP HANA和ache Cassandra。更多关于内存数据库相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

675

2023.11.14

mongodb和redis哪个读取速度快
mongodb和redis哪个读取速度快

redis 的读取速度比 mongodb 更快。原因包括:1. redis 使用简单的键值存储,而 mongodb 存储 json 格式的数据,需要解析和反序列化。2. redis 使用哈希表快速查找数据,而 mongodb 使用 b-tree 索引。因此,redis 在需要高性能读取操作的应用程序中是一个更好的选择。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

501

2024.04.02

redis怎么做缓存服务器
redis怎么做缓存服务器

redis 作为缓存服务器的答案:redis 是一款开源、高性能、分布式的键值存储,可作为缓存服务器使用。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

416

2024.04.07

redis怎么解决数据一致性
redis怎么解决数据一致性

redis 提供了两种一致性模型,以维护副本数据一致性:强一致性 (sync) 确保写操作仅在复制到所有从节点后才完成;最终一致性 (async) 则在主节点上写操作后认为已完成,牺牲一致性换取性能。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

410

2024.04.07

bootstrap安装教程
bootstrap安装教程

本专题整合了bootstrap安装相关教程,阅读专题下面的文章了解更多详细操作教程。

22

2026.03.18

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号