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

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

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

过期键删除策略

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

定时删除

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

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

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

惰性删除

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

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

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

定期删除

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

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

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

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

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

Redis的过期键删除策略

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

相关推荐
Bony-1 小时前
Go语言垃圾回收机制详解与图解
开发语言·后端·golang
REDcker2 小时前
Redis容灾策略与哈希槽算法详解
redis·算法·哈希算法
闻哥4 小时前
Redis 避坑指南:从命令到主从的全链路踩坑实录
java·数据库·redis·缓存·面试·springboot
小毅&Nora5 小时前
【后端】【Redis】② Redis事务管理全解:从“购物车结算“到“银行转账“,一文彻底掌握事务机制
数据库·redis·事务
JH30736 小时前
SpringBoot自定义启动banner:给项目加个专属“开机画面”
java·spring boot·后端
假女吖☌6 小时前
限流算法-redis实现与java实现
java·redis·算法
what丶k6 小时前
深度解析Redis LRU与LFU算法:区别、实现与选型
java·redis·后端·缓存
菜宾6 小时前
java-redis面试题
java·开发语言·redis
测试人社区-浩辰7 小时前
AI与区块链结合的测试验证方法
大数据·人工智能·分布式·后端·opencv·自动化·区块链
老友@8 小时前
分布式事务完全演进链:从单体事务到 TCC 、Saga 与最终一致性
分布式·后端·系统架构·事务·数据一致性