键虽然被设置了过期时间,但是当过期以后是如何处理的呢?通常有三种规则:
定时删除:在设置了键的过期时间后,会启动一个计时器,当键的计时器到期就删除该键。
惰性删除:不创建计时器,过期也不做处理,当再次读取该键的时候先去去判断是否过期,如果过期就删除并返回空,如果没有过期就返回值。
定期删除:这个很好理解,过一段时间清理一次,至于是否全部清除不一定,因为如果键过多,整体清理肯定会消耗大量的CPU时间,所以定期清除可能是定期清除一部分,然后在一个整体的定期清除周期里完成整体清除。
策略 | 优点 | 缺点 |
定时删除 | 对于内存空间来讲最有效,不存储任何过期数据 | 频繁的删除过期数据会占用较多的CPU时间 |
惰性删除 | 不占用过多的CPU时间 | 数据库会存在大量过期数据,占用内存空间 |
定期删除 | 吸取定时和惰性删除的优点 | 要设计一个好的删除操作占用时长和执行频率 |
Redis所使用的就是惰性删除和定期删除两种策略。也就是说它会定期执行删除过期键的操作,但是又不是一次遍历所有键,而是定期遍历一部分,在一个长周期内达到遍历所有。在还没有到达定期删除的时间段内,使用惰性删除,遇到过期的就删除,没有遇到的则保留,留给定期删除处理。通过这种机制就在内存和CPU之间寻求了一种平衡。
定期删除操作的周期是默认100毫秒,这个是由serverCron周期操作函数来执行的。但是每次删除操作执行多长时间已经以及遍历多少数据库这个是由具体算法来决定的。