0

0

Redis如何处理大量的瞬时过期数据

P粉602998670

P粉602998670

发布时间:2026-03-16 12:20:01

|

379人浏览过

|

来源于php中文网

原创

会,大量key同时过期会引发CPU尖峰、内存延迟释放和请求抖动;Redis通过每100ms随机抽样检查过期key,超25%过期则连续多轮高强度扫描删除,导致延迟飙升甚至超时。

redis如何处理大量的瞬时过期数据

大量key同时过期会卡住Redis吗? 会,但不是“直接卡死”,而是触发CPU尖峰 + 内存延迟释放 + 请求响应抖动。Redis默认每100ms做一次随机抽样检查(activeExpireCycle),如果某次抽样发现超过25%的样本已过期,它会立刻再执行一轮——这在大量key集中过期时,可能连续多轮高强度扫描+删除,把CPU吃满,导致正常请求延迟飙升甚至超时。

常见错误现象包括:INFO commandstatscmdstat_expire 耗时突增、used_cpu_sysused_cpu_user 飙升、客户端出现大量 timeoutREADONLY(主从切换误判)错误。

  • 不要依赖“反正有惰性删除兜底”——冷数据不访问,过期key就一直占内存
  • 不要全量用 EXPIREAT 算同一个时间戳——哪怕只差1毫秒,也比完全同步强
  • Redis 7.0+ 的 lazyfree-lazy-expire yes 可让过期删除异步化,但仅对定期删除生效,惰性删除仍同步删

怎么分散过期时间才真正有效? “加个随机数”不够,得看业务容忍度和key规模。比如10万条用户token统一设30分钟过期,直接加±90秒(即29.5~30.5分钟)只是把压力摊到2分钟内,依然可能压垮单个redis实例。

更稳妥的做法是分层打散:

  • 按key前缀或用户ID哈希分桶,每桶设置不同基础过期时间(如桶0→1780s,桶1→1792s…)
  • 对时效性敏感的(如短信验证码),用 PEXPIRE + 毫秒级偏移(rand(100, 500)),避免秒级对齐
  • 对批量写入场景(如导入缓存),用pipeline分批提交,每批内再打散过期时间,别一次性塞5000个同过期key

注意:TTL 返回 -2 表示key已过期但尚未被清理,此时它还在内存里,只是“逻辑不可见”——这种僵尸key堆积多了,mem_fragmentation_ratio 会悄悄升高。

定期删除机制到底在查什么? Redis不是遍历整个数据库,而是在每个db的过期字典(expires dict)里随机采样。这个字典只存设置了过期时间的key,所以没设过期的key完全不影响它。

关键点在于:

课游记AI
课游记AI

AI原生学习产品

下载
  • 采样数量由 ACTIVE_EXPIRE_CYCLE_LOOKUPS_PER_LOOP 控制(默认20),但实际每次最多删10个过期key,防止单次操作太久
  • 如果某个db里过期key占比长期高于25%,Redis会加大扫描力度,可能持续占用10%~30% CPU
  • CONFIG GET active-expire-effort(6.2+)可调扫描强度,但值过高反而引发抖动,生产环境不建议动

你可以用这个命令快速看当前库有多少待清理的过期key:EVAL "return #redis.call('ZCOUNT', 'redis_expires', '-inf', '+inf')" 0(需提前用Lua建索引)或更轻量的 DBSIZE 对比 INFO keyspace 中各db的 keysexpires 字段。

监控哪些指标能提前发现问题? 别等报警才看,日常盯紧三个地方:
  • expired_keys(累计删除数):突增说明刚经历一波过期高峰
  • evicted_keys:如果它跟着涨,说明过期key没及时清完,内存吃紧后触发了淘汰策略
  • mem_fragmentation_ratio > 1.5 且持续上升:大概率是过期key删得慢,内存碎片堆积

顺手加个简单巡检脚本:

redis-cli INFO | grep -E "(expired_keys|evicted_keys|mem_fragmentation_ratio)"

真正麻烦的不是过期本身,而是“过期但没删干净”+“删的时候又撞上大流量”。这两件事叠在一起,比单纯数据量大还难定位。

相关标签:

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

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

WorkBuddy
WorkBuddy

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
登录token无效
登录token无效

登录token无效解决方法:1、检查token的有效期限,如果token已经过期,需要重新获取一个新的token;2、检查token的签名,如果签名不正确,需要重新获取一个新的token;3、检查密钥的正确性,如果密钥不正确,需要重新获取一个新的token;4、使用HTTPS协议传输token,建议使用HTTPS协议进行传输 ;5、使用双因素认证,双因素认证可以提高账户的安全性。

6679

2023.09.14

登录token无效怎么办
登录token无效怎么办

登录token无效的解决办法有检查Token是否过期、检查Token是否正确、检查Token是否被篡改、检查Token是否与用户匹配、清除缓存或Cookie、检查网络连接和服务器状态、重新登录或请求新的Token、联系技术支持或开发人员等。本专题为大家提供token相关的文章、下载、课程内容,供大家免费下载体验。

845

2023.09.14

token怎么获取
token怎么获取

获取token值的方法:1、小程序调用“wx.login()”获取 临时登录凭证code,并回传到开发者服务器;2、开发者服务器以code换取,用户唯一标识openid和会话密钥“session_key”。想了解更详细的内容,可以阅读本专题下面的文章。

1092

2023.12.21

token什么意思
token什么意思

token是一种用于表示用户权限、记录交易信息、支付虚拟货币的数字货币。可以用来在特定的网络上进行交易,用来购买或出售特定的虚拟货币,也可以用来支付特定的服务费用。想了解更多token什么意思的相关内容可以访问本专题下面的文章。

2220

2024.03.01

堆和栈的区别
堆和栈的区别

堆和栈的区别:1、内存分配方式不同;2、大小不同;3、数据访问方式不同;4、数据的生命周期。本专题为大家提供堆和栈的区别的相关的文章、下载、课程内容,供大家免费下载体验。

448

2023.07.18

堆和栈区别
堆和栈区别

堆(Heap)和栈(Stack)是计算机中两种常见的内存分配机制。它们在内存管理的方式、分配方式以及使用场景上有很大的区别。本文将详细介绍堆和栈的特点、区别以及各自的使用场景。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

606

2023.08.10

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

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

1007

2023.11.02

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

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

674

2023.11.14

C++多线程并发控制与线程安全设计实践
C++多线程并发控制与线程安全设计实践

本专题围绕 C++ 在高性能系统开发中的并发控制技术展开,系统讲解多线程编程模型与线程安全设计方法。内容包括互斥锁、读写锁、条件变量、原子操作以及线程池实现机制,同时结合实际案例分析并发竞争、死锁避免与性能优化策略。通过实践讲解,帮助开发者掌握构建稳定高效并发系统的关键技术。

2

2026.03.16

热门下载

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

精品课程

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

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