Redis的数据过期策略——Java全栈知识(18)

1、定期删除

定期删除:Redis 默认每隔 100 ms 就随机抽取一些设置了过期时间的 key, 并检查其是否过期,如果过期就删除。定期删除是 Redis 的主动删除策略,它可以确保过期的 key 能够及时被删除,

但是会占用 CPU 资源去扫描 key, 可能会影响 Redis 的性能。

2、惰性删除

惰性删除:当一个 key 过期时,不会立即从内存中删除,而是在访问这个 key 的时候才会触发删除操作。惰性删除是 Redis 的被动删除策略,它可以节省 CPU 资源,但是会导致过期的 key 始终保存在内存中,占用内存空间。

3、Redis 默认使用的数据过期策略

定期删除会在 Redis 设置的过期键的过期时间达到一定阈值时进行一次扫描,将过期的键删除,但不会立即释放内存,而是把这些键标记为"已过期",并放入一个专门的链表中。然后,在 Redis 的内存使用率达到定阈值时,Redis会对这些"已过期"的键进行一次内存回收操作,释放被这些键占用的内存空间。

而惰性删除则是在键被访问时进行过期检查,如果过期了则删除键并释放内存。需要注意的是,即使 Redis 进行了内存回收操作,也不能完全保证被删除的内存空间会立即被系统回收。

一般来说,这些被删除的内存空间会被操作系统标记为"可重用的内存",等待被重新分配。因此,即使 Redis 进行了内存回收操作,也并不能保证 Redis 所占用的内存空间会立即释放给操作系统。

相关推荐
重生之我是Java开发战士16 分钟前
【数据结构】Java集合框架:List与ArrayList
java·数据结构·list
lucky_lyovo21 分钟前
Neo4j--登录及简单操作
数据库·neo4j
爱干饭的boy31 分钟前
手写Spring底层机制的实现【初始化IOC容器+依赖注入+BeanPostProcesson机制+AOP】
java·数据结构·后端·算法·spring
影子240136 分钟前
java jdbc连接sqlserver2008R2版本数据库报错,驱动程序无法通过使用安全套接字层(SSL)加密与 SQL Server 建立安全连接
java·数据库·ssl
0_0梅伊阁诗人1 小时前
Django ORM 模型
开发语言·数据库·笔记·python·oracle·django
失散131 小时前
分布式专题——10.1 ShardingSphere介绍
java·分布式·架构·shardingsphere·分库分表
记得开心一点嘛1 小时前
手搓Tomcat
java·tomcat
倔强的石头1061 小时前
Windows系统下KingbaseES数据库保姆级安装教程(附常见问题解决)
数据库·windows
躲在云朵里`1 小时前
Redis深度解析:核心数据结构、线程模型与高频面试题
数据结构·数据库·redis
m0_453806871 小时前
【已解决】mongoose在mongodb中添加数据,数据库默认复数问题
数据库·mongodb