Redis内存回收 - 过期键删除策略

Redis允许我们对键设置一个过期时间。当一个键过期后,这个键就不可获取,会被Redis删除。

那么这个过期的键,什么时候被删除呢?下文就介绍下Redis的过期键删除策略。

过期键删除策略

过期键删除策略有3种:定时删除、惰性删除、定期删除。

定时删除

在设置键的过期时间的同时,创建一个定时器,让定时器在键到期的时候立即执行对键的删除策略。

定时删除对内存最友好,但是对于CPU时间最不友好。

定时删除在键过期后立刻删除,能够及时回收键占用的空间。但是,删除键这一行为会占用CPU时间,当内存不紧张但CPU时间非常紧张的情况下,这一策略会对服务器的响应时间和吞吐量造成影响。

惰性删除

每次获取键的时候,检查键是否过期,过期就删除该键。

惰性删除对CPU时间最友好,但是对于内存非常不友好。

在使用惰性删除策略时,若一些过期键很少被访问,甚至永远也不会被访问,那么这些键就永远也不会删除。我们甚至可以把这种情况看作是一种内存泄漏。

定期删除

每隔一段时间,就对数据库进行一次检查,删除过期的键。至于要删除多少键、检查多少数据库,则由算法决定。

定期删除策略是前两种策略的整合和折中。

上面两种策略在单独使用的时候都有明显的缺点:

  • 定时删除占用太多CPU时间,影响服务器的响应时间和吞吐量。
  • 惰性删除浪费太多内存,有内存泄漏的危险。

定期删除策略的难点是确定删除操作执行的时长和频率。

Redis的过期键删除策略

Redis服务器实际采用的是惰性删除和定期删除两种策略,通过配合使用这两种策略,服务器可以很好的在合理使用CPU时间和避免浪费内存空间之间取得平衡。

相关推荐
Tttian62211 分钟前
基于Pycharm与数据库的新闻管理系统(2)Redis
数据库·redis·pycharm
小池先生31 分钟前
springboot启动不了 因一个spring-boot-starter-web底下的tomcat-embed-core依赖丢失
java·spring boot·后端
言之。1 小时前
redis延迟队列
redis
小蜗牛慢慢爬行2 小时前
如何在 Spring Boot 微服务中设置和管理多个数据库
java·数据库·spring boot·后端·微服务·架构·hibernate
hanbarger2 小时前
nosql,Redis,minio,elasticsearch
数据库·redis·nosql
弗罗里达老大爷2 小时前
Redis
数据库·redis·缓存
wm10432 小时前
java web springboot
java·spring boot·后端
龙少95434 小时前
【深入理解@EnableCaching】
java·后端·spring
溟洵6 小时前
Linux下学【MySQL】表中插入和查询的进阶操作(配实操图和SQL语句通俗易懂)
linux·运维·数据库·后端·sql·mysql
SomeB1oody8 小时前
【Rust自学】6.1. 定义枚举
开发语言·后端·rust