Spring Data Redis存储库使用多个Redis功能将域对象持久存储在Redis中。
域对象主要存储在哈希(
job:a6d6e491-5d75-4fd0-bd8e-71692f6d18be)中。任何有效期都直接应用于哈希,因此Redis可以使密钥期满。弹簧Redis的数据也保持次级索引(
job:campaignId:aa,
job:recipient:dd)由特定的字段值提供查找。集合中的各个元素不能过期。只有整个数据结构都可以过期,但这不是您要执行的操作,因为所有未过期的元素都将以这种方式消失。
因此,Spring Data
Redis将原始哈希的副本作为幻影哈希(
job:a6d6e491-5d75-4fd0-bd8e-71692f6d18be:phantom)保留,并具有稍长的TTL。
Spring Data Redis订阅键事件(设置为
@EnableRedisRepositories(enableKeyspaceEvents =EnableKeyspaceEvents.ON_STARTUP)以监听到期事件。原始哈希值过期后,Spring Data
Redis会立即加载幻像哈希值以执行清理(从二级索引中删除引用)。
未执行数据清理的原因可能有多种:
- 如果您运行控制台应用程序只是为了插入数据并终止,那么到期将删除哈希值,但由于您的应用程序不再运行而不会执行索引清除。Redis发布的任何事件都是暂时的,如果您的应用程序未在监听,则这些事件将丢失
- 如果仅启用了存储库支持
@EnableRedisRepositories
(不启用keyspace-events),则Keyspace事件侦听器不会处于活动状态,并且Spring Data Redis不会订阅任何到期事件。



