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 使用的是惰性删除与定期删除相结合的策略,同时也提供了一系列的内存淘汰机制。

相关推荐
陌上丨2 小时前
Redis的Key和Value的设计原则有哪些?
数据库·redis·缓存
AI_56783 小时前
AWS EC2新手入门:6步带你从零启动实例
大数据·数据库·人工智能·机器学习·aws
ccecw3 小时前
Mysql ONLY_FULL_GROUP_BY模式详解、group by非查询字段报错
数据库·mysql
JH30733 小时前
达梦数据库与MySQL的核心差异解析:从特性到实践
数据库·mysql
数据知道3 小时前
PostgreSQL 核心原理:如何利用多核 CPU 加速大数据量扫描(并行查询)
数据库·postgresql
麦聪聊数据4 小时前
Web 原生架构如何重塑企业级数据库协作流?
数据库·sql·低代码·架构
未来之窗软件服务5 小时前
数据库优化提速(四)新加坡房产系统开发数据库表结构—仙盟创梦IDE
数据库·数据库优化·计算机软考
时艰.5 小时前
Java 并发编程 — 并发容器 + CPU 缓存 + Disruptor
java·开发语言·缓存
Goat恶霸詹姆斯6 小时前
mysql常用语句
数据库·mysql·oracle
大模型玩家七七6 小时前
梯度累积真的省显存吗?它换走的是什么成本
java·javascript·数据库·人工智能·深度学习