Redis的键过期是如何删除的?【面试高频】

大家好,这里是程序员阿亮。这一次咱们来聊一下Redis的键过期是如何处理的

前言

当我们Redis的key设置了过期时间,很多人会疑问,Redis是如何进行过期key的删除操作的,其实,Redis为了保证高可用和高性能,在这一步也做了很多的优化。

Redis的key过期又有俩种,一种是主动过期,一种是被动过期。

一、被动过期

当我们去访问一个key,发现这个key已经过期了,那么Redis会马上删除这个key,这就很简单了,就不过多解释了。

当然仅仅靠着这个主动删除是不够的,如果有一些key已经不会被访问,那么就会积压在内存中,所以Redis会主动去处理它们,那就可以考虑到主动过期了。

二、主动过期

主动过期的策略

Redis 在后台每秒执行 10 次(即每 100ms 一次)的定时任务,每次执行以下步骤:

1. 随机采样

从设置了过期时间的 key 集合(expires dict)中,随机抽取最多 20 个 key

2. 检查是否过期

对这 20 个 key 逐一检查当前时间是否超过其过期时间。

3. 删除过期 key

删除所有已过期的 key。

4. 动态调整采样频率
  • 如果本次采样中过期 key 的比例 ≥ 25% ,说明还有很多过期 key 没删完 → 立即重复执行上述过程(递归),直到比例 < 25% 或达到最大执行时间(防止阻塞主线程)。
  • 这种设计既保证了效率,又避免过度消耗 CPU。

注意:为避免阻塞主线程,每次主动过期操作的总耗时不能超过 25ms(Redis 6+ 版本有更精细的限制)。


总结

所以Redis不保证key一过期就马上删除,因为惰性删除是要等到下一次访问才能删除,而我们的主动删除则为了低延迟和采用轮询方式,并且时长有限定,所以不能马上删除过期key。

相关推荐
189228048611 小时前
NY352固态MT29F32T08GWLBHD6-24QJ:B
大数据·服务器·人工智能·科技·缓存
AI视觉网奇1 小时前
linux 检索库 判断库是否支持
java·linux·服务器
海市公约2 小时前
MySQL更新语句执行全流程:从Buffer Pool修改到二阶段提交
数据库·mysql·binlog·innodb·undo log·二阶段提交·update执行原理
她的男孩2 小时前
从零搭一个企业后台,为什么我把能力拆成 Starter 和 Plugin
java·后端·架构
RainCity2 小时前
Java Swing 自定义组件库分享(七)
java·笔记·后端
Sam_Deep_Thinking2 小时前
连锁门店的外卖订单平台对接
java·微服务·架构·系统架构
颂love2 小时前
MySQL的执行流程
android·数据库·mysql
丷丩2 小时前
三级缓存下MVT地图瓦片服务性能优化策略
算法·缓存·性能优化·gis·geoai-up
_遥远的救世主_2 小时前
从一次结果集密集型查询 OOM 看 Java 服务的稳定性架构治理
java·后端
一楼的猫3 小时前
从工具链视角对比:番茄作家助手 vs 第三方写作辅助方案
java·服务器·开发语言·前端·学习·chatgpt·ai写作