Redis针对过期key的删除策略

Redis使用三种策略处理过期key:定时删除、惰性删除和定期删除。定时删除在key过期时立即删除,最节省内存但可能消耗较多CPU时间。惰性删除在获取key时检查并删除过期key,最节省CPU时间但可能导致内存浪费。定期删除则是两者折中,按固定周期检查并删除过期key,防止过度消耗CPU和内存。Redis实际采用惰性和定期删除策略结合,平衡资源使用。
摘要由CSDN通过智能技术生成

Redis数据库键的过期时间都保存在过期字典中,可使用exit key 或ttl key 或者pttl key命令判断key是否过期。若内存中存放的key-value对较多,Redis应该如何才能保证不影响查询效率又能控制其中的有效缓存?(尽可能保证Redis中存放的key是未过期的key)。
这个问题有三种可能的答案,分别代表了三种不同的过期删除策略:

  • 定时删除:在设置key的过期时间的同时,创建一个定时器,让定时器在key的过期时间来临时,立即执行对key的删除操作;
  • 惰性删除:放任key过期不管,但是每次从key空间中获取key时,都检查取得的key是否过期,如果过期的话,就删除该key,如果没有过期就返回该key;
  • 定期删除:每隔一段时间程序就对数据库进行一次检查,删除里面的过期key,至于要删除多少过期key,以及要检查多少个数据库,则由算法决定。
  • 在这三种策略中,第一种和第三种是主动删除策略,第二种是被动删除策略。

1.定时删除:

定时删除策略对内存是最友好的:通过使用定时器,定时器删除策略可以保证过期key会尽可能快的被删除,并释放过期key所占用的内存。
另一方面定时删除策略缺点是,它对CPU时间是最不友好的:在过期key较多的情况下,删除过期key这一行为可能会占用相当一部分CPU时间,在内存不紧张但是CPU时间非常紧张的情况下,将CPU时间用在删除和当前任务无关的过期key上,无疑会对服务器的响应时间和吞吐量造成影响。

2.惰性删除:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值