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 所占用的内存空间会立即释放给操作系统。

相关推荐
PEI0421 小时前
MVCC(多版本并发控制)
java·开发语言·数据库
码出财富21 小时前
事务管理的选择:为何 @Transactional 并非万能,TransactionTemplate 更值得信赖
数据库
ST.J21 小时前
SQL与数据库笔记
数据库·笔记·sql
PXM的算法星球1 天前
ZooKeeper vs Redis:分布式锁的实现与选型指南
redis·分布式·zookeeper
半夏陌离1 天前
SQL 实战指南:电商订单数据分析(订单 / 用户 / 商品表关联 + 统计需求)
java·大数据·前端
我真的是大笨蛋1 天前
K8S-Pod(上)
java·云原生·容器·kubernetes
jllws11 天前
数据库原理及应用_数据库管理和保护_第5章数据库的安全性_理论部分
数据库
纪元A梦1 天前
贪心算法应用:数字孪生同步问题详解
java·算法·贪心算法
寒士obj1 天前
Redisson分布式锁:看门狗机制与续期原理
redis·分布式