一尘不染

Spring Redis-主条目到期后未删除索引

redis

我正在使用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。

他们为什么不删除自己?我该怎么办?


阅读 349

收藏
2020-06-20

共1个答案

一尘不染

Spring Data Redis存储库使用多个Redis功能将域对象持久存储在Redis中。

域对象主要存储在哈希(job:a6d6e491-5d75-4fd0-bd8e-71692f6d18be)中。任何有效期都直接应用于哈希,因此Redis可以使密钥期满。弹簧Redis的数据也保持次级索引(job:campaignId:aajob:recipient:dd)由特定的字段值提供查找。集合中的各个元素不能过期。只有整个数据结构都可以过期,但这不是您要执行的操作,因为所有未过期的元素都将以这种方式消失。

因此,Spring Data
Redis将原始哈希的副本作为幻影哈希(job:a6d6e491-5d75-4fd0-bd8e-71692f6d18be:phantom)保留,并具有稍长的TTL。

Spring Data Redis订阅键事件(设置为@EnableRedisRepositories(enableKeyspaceEvents = EnableKeyspaceEvents.ON_STARTUP)以监听到期事件。原始哈希值过期后,Spring Data
Redis会立即加载幻像哈希值以执行清理(从二级索引中删除引用)。

未执行数据清理的原因可能有多种:

  1. 如果您运行控制台应用程序只是为了插入数据并终止,那么到期将删除哈希值,但由于您的应用程序不再运行而不会执行索引清除。Redis发布的任何事件都是暂时的,如果您的应用程序未在监听,则这些事件将丢失
  2. 如果仅启用了存储库支持@EnableRedisRepositories(不启用keyspace-events),则Keyspace事件侦听器不会处于活动状态,并且Spring Data Redis不会订阅任何到期事件。
2020-06-20