定时删除:
-
每个设置了TTL的key中都会创建一个计时器,等到过期时间就会立即删除
-
对内存友好,但是会占用大量的CPU资源去处理过期数据,从而影响缓存的吞吐量和响应时间
惰性删除:
-
设置了key的过期后,不会立即删除,而是当我们访问的时候,会检查该key是否已过期,如果过期则删除,没有过期则继续使用
-
对可以最大化地节省CPI资源,但是十分消耗内存,在极端情况下,可能会出翔大量的过期key没有被再次访问,从而一直存在内存中没有被释放
定期删除:
-
每隔一段时间,扫描一定数量的数据库的expires字典中一定数量的随机key,删除其中已过期的数据
-
可以通过限制删除操作执行的时长和频率来减少删除操作对CPU影响
-
slow模式,执行频率默认为10hz,每次不超过25ms
-
fast模式:执行频率不固定,两次间隔不低于2ms,每次耗时不超过1ms