Redis 的 key 的过期策略是怎么实现的

在 Redis 中,有一个 expire 命令,用来设置某个 key 的过期时间,当超过这个时间后,这个 key 就被删除了,我们也就获取不到了,但是 Redis 是如何做到对于每一个设置了过期时间的 key 都能按时删除的呢?

1、直接遍历所有的 key

每隔一段时间,Redis 就遍历一遍所有的 key,若某个 key 已经到了或已经超过的过期时间,就将其删除。

这种策略对于 Redis 中的 key 很少时是有效的,但是当 Redis 中的值变得非常多,每遍历一遍所有的 key 就会消耗较多的 CPU 资源,而且由于 Redis 是单线程的程序,若在这里消耗了太多的资源,就导致别的请求无法顺利进行,从而造成程序出现错误。

2、惰性删除

当给某个 key 设置过期时间后,虽然这个 key 已经过期了,但是 Redis 还没有将其删除,当下一次获取到这个 key 后,系统就会判断这个 key 已经到了过期时间,就会将其删除,并且返回 nil。

3、定期删除

与第一种方法类似,但是不是一次性遍历所有的 key,而是只抽取部分 key 进行过期时间的验证,这样就能保证既即时删除了过期的 key,又能保证不会消耗过多的资源。

Redis 使用的是惰性删除与定期删除相结合的策略,同时也提供了一系列的内存淘汰机制。

相关推荐
qq_124987075315 分钟前
基于JavaWeb的大学生房屋租赁系统(源码+论文+部署+安装)
java·数据库·人工智能·spring boot·计算机视觉·毕业设计·计算机毕业设计
倒流时光三十年1 小时前
SpringBoot 数据库同步 Elasticsearch 性能优化
数据库·spring boot·elasticsearch
forestsea1 小时前
深入理解Redisson RLocalCachedMap:本地缓存过期策略全解析
redis·缓存·redisson
码农小卡拉1 小时前
深入解析Spring Boot文件加载顺序与加载方式
java·数据库·spring boot
佛祖让我来巡山1 小时前
Redis 为什么这么快?——「极速快递站」的故事
redis·redis为什么快?
怣501 小时前
MySQL多表连接:全外连接、交叉连接与结果集合并详解
数据库·sql
wjhx2 小时前
QT中对蓝牙权限的申请,整理一下
java·数据库·qt
冰暮流星2 小时前
javascript之二重循环练习
开发语言·javascript·数据库
万岳科技系统开发2 小时前
食堂采购系统源码库存扣减算法与并发控制实现详解
java·前端·数据库·算法
冉冰学姐2 小时前
SSM智慧社区管理系统jby69(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面
数据库·管理系统·智慧社区·ssm 框架