温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

Redis(五):关于过期键(2)过期键的删除

发布时间:2020-07-13 16:15:35 来源:网络 阅读:461 作者:linuxjavachen 栏目:数据库

键虽然被设置了过期时间,但是当过期以后是如何处理的呢?通常有三种规则:

定时删除:在设置了键的过期时间后,会启动一个计时器,当键的计时器到期就删除该键。

惰性删除:不创建计时器,过期也不做处理,当再次读取该键的时候先去去判断是否过期,如果过期就删除并返回空,如果没有过期就返回值。

定期删除:这个很好理解,过一段时间清理一次,至于是否全部清除不一定,因为如果键过多,整体清理肯定会消耗大量的CPU时间,所以定期清除可能是定期清除一部分,然后在一个整体的定期清除周期里完成整体清除。

策略优点缺点
定时删除对于内存空间来讲最有效,不存储任何过期数据频繁的删除过期数据会占用较多的CPU时间
惰性删除不占用过多的CPU时间数据库会存在大量过期数据,占用内存空间
定期删除吸取定时和惰性删除的优点要设计一个好的删除操作占用时长和执行频率

Redis所使用的就是惰性删除和定期删除两种策略。也就是说它会定期执行删除过期键的操作,但是又不是一次遍历所有键,而是定期遍历一部分,在一个长周期内达到遍历所有。在还没有到达定期删除的时间段内,使用惰性删除,遇到过期的就删除,没有遇到的则保留,留给定期删除处理。通过这种机制就在内存和CPU之间寻求了一种平衡。


定期删除操作的周期是默认100毫秒,这个是由serverCron周期操作函数来执行的。但是每次删除操作执行多长时间已经以及遍历多少数据库这个是由具体算法来决定的。

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI