我正在使用Spring Data Repository保存新条目。每个条目的TTL为10秒。
当我保存带有索引的条目时,这就是我在Redis中得到的
127.0.0.1:6379> keys * 1) "job:campaignId:aa" 2) "job:a6d6e491-5d75-4fd0-bd8e-71692f6d18be" 3) "job:recipient:dd" 4) "job:a6d6e491-5d75-4fd0-bd8e-71692f6d18be:phantom" 5) "job:listId:cc" 6) "job:accountId:bb" 7) "job" 8) "job:a6d6e491-5d75-4fd0-bd8e-71692f6d18be:idx"
到期后,我仍然有数据:
127.0.0.1:6379> keys * 1) "job:campaignId:aa" 2) "job:recipient:dd" 3) "job:listId:cc" 4) "job:accountId:bb" 5) "job" 6) "job:a6d6e491-5d75-4fd0-bd8e-71692f6d18be:idx"
没有任何TTL。
他们为什么不删除自己?我该怎么办?
Spring Data Redis存储库使用多个Redis功能将域对象持久存储在Redis中。
域对象主要存储在哈希(job:a6d6e491-5d75-4fd0-bd8e-71692f6d18be)中。任何有效期都直接应用于哈希,因此Redis可以使密钥期满。弹簧Redis的数据也保持次级索引(job:campaignId:aa,job:recipient:dd)由特定的字段值提供查找。集合中的各个元素不能过期。只有整个数据结构都可以过期,但这不是您要执行的操作,因为所有未过期的元素都将以这种方式消失。
job:a6d6e491-5d75-4fd0-bd8e-71692f6d18be
job:campaignId:aa
job:recipient:dd
因此,Spring Data Redis将原始哈希的副本作为幻影哈希(job:a6d6e491-5d75-4fd0-bd8e-71692f6d18be:phantom)保留,并具有稍长的TTL。
job:a6d6e491-5d75-4fd0-bd8e-71692f6d18be:phantom
Spring Data Redis订阅键事件(设置为@EnableRedisRepositories(enableKeyspaceEvents = EnableKeyspaceEvents.ON_STARTUP)以监听到期事件。原始哈希值过期后,Spring Data Redis会立即加载幻像哈希值以执行清理(从二级索引中删除引用)。
@EnableRedisRepositories(enableKeyspaceEvents = EnableKeyspaceEvents.ON_STARTUP
未执行数据清理的原因可能有多种:
@EnableRedisRepositories