https://redis.io/docs/manual/keyspace-notifications/#timing-of-expired-events
简单的意思就是不能保证时效性,key过期事件可能会往后推个几分钟才触发,特别是数据量越来越大的时候。
而且一旦客户端处理失败,这个事件也不会重发,会丢失这个事件。
并且对于集群模式下,某一个节点的key事件被触发了并不会扩散到所有节点。所以客户端需要订阅每个redis实例节点。


惰性删除+主动删除
惰性删除:主动访问key的时,会先对key进行超时判断,过时的key会立即删除;
主动删除:redis会在后台,每秒10次的执行如下操作:随机选取100个key校验是否过期,如果有25个以上的key过期了,立刻额外随机选取下100个key。也就是说,如果过期的key不多,redis最多每秒回收200条左右;
这样即使从不被访问的数据,过期了也会被删除掉。
RDB模式下备份和恢复都会检查过期key
AOF
在备份的时候会追加key del命令。在重写的时候会将已过期的key排除掉