redis的key过期事件不建议实现延时消息的原因
创始人
2024-03-22 00:47:56

官网的解释

https://redis.io/docs/manual/keyspace-notifications/#timing-of-expired-events

简单的意思就是不能保证时效性,key过期事件可能会往后推个几分钟才触发,特别是数据量越来越大的时候。

而且一旦客户端处理失败,这个事件也不会重发,会丢失这个事件。

并且对于集群模式下,某一个节点的key事件被触发了并不会扩散到所有节点。所以客户端需要订阅每个redis实例节点。

在这里插入图片描述

在这里插入图片描述

redis key过期事件原理

惰性删除+主动删除

惰性删除:主动访问key的时,会先对key进行超时判断,过时的key会立即删除;

主动删除:redis会在后台,每秒10次的执行如下操作:随机选取100个key校验是否过期,如果有25个以上的key过期了,立刻额外随机选取下100个key。也就是说,如果过期的key不多,redis最多每秒回收200条左右;
这样即使从不被访问的数据,过期了也会被删除掉。

持久化对过期key的处理

RDB模式下备份和恢复都会检查过期key

  1. 从内存数据库持久化数据到RDB文件,持久化key之前,会检查是否过期,过期的key不进入RDB文件
  2. 从RDB文件恢复数据到内存数据库,数据载入数据库之前,会对key先进行过期检查,如果过期,不导入数据库(主库情况)

AOF
在备份的时候会追加key del命令。在重写的时候会将已过期的key排除掉

  1. 从内存数据库持久化数据到AOF文件:当key过期后,还没有被删除,此时进行执行持久化操作(该key是不会进入aof文件的,因为没有发生修改命令)当key过期后,在发生删除操作时,程序会向aof文件追加一条del命令(在将来的以aof文件恢复数据的时候该过期的键就会被删掉)
  2. AOF重写:重写时,会先判断key是否过期,已过期的key不会重写到aof文件

相关内容

热门资讯

青海省房屋建筑和市政基础设施限... 附件 2 青海省房屋市政限额以下工程竣工销项登记表附件 3 限额以下工程施工安全管理承诺书附件 4 ...
最新或2023(历届)首都师范... 首都师范大学创建于1954年,是一所包括文、理、工、管、法、教育、外语、艺术等专业的综合性师范大学,...
最新或2023(历届)南京中医... 南京中医药大学始建于1954年,历经江苏省中医进修学校、江苏省中医学校、南京中医学院、江苏新医学院、...
最新或2023(历届)徐州医学... 徐州医科大学的历史可追溯至创办于1934 年的江苏省立医政学院。1958 年成立南京医学院徐州分院,...
最新或2023(历届)南京医科...  南京医科大学创建于1934年,时名江苏省立医政学院。1957年,由镇江迁至南京,更名为南京医学院。...