首页 文章

集成员的TTL

提问于
浏览
45

Redis是否可以设置TTL(生存时间)而不是特定键,而是设置成员?

我使用Redis文档提出的标签结构 - 数据是简单的键值对,标签是包含与每个标签对应的键的集合,例如

> SETEX id:id_1 100 'Lorem ipsum'
OK
> SADD tag:tag_1 id:id_1
(integer) 1

id:id_1 将按预期到期但我没有看到从 tag:tag_1 集中删除相应成员的有效方法 .

我提出的一种方法是使用包含脚本的cron作业,该脚本将定期从集合中删除过期的密钥 - 通过将所有标记名称添加到另一个集合,然后遍历所有标记,然后对应于每个标记的所有ID并检查是否存在相应的密钥 - 如果不存在,则调用 SREM .

我不认为这将是一种有效的方式,我可能希望尽可能保持标签清洁,因为集合的大小可能会影响多个标签搜索的性能( SINTER ) . 还有更多"internal"方式吗?

2 回答

  • 20

    无法直接使列表,集或zsets中的项目失效 .

    您需要实现一种机制,以便在主项目到期时得到通知,以便您可以相应地维护相应的集合 .

    看到这个问题的答案,我认为它适用于你的用例(用id替换session,用tag替换用户):

    Redis, session expiration, and reverse lookup

  • 34

    不,这是不可能的(和not planned either) . recommended方法是使用将得分设置为时间戳的有序集,然后手动删除过期的密钥 . 要查询非过期密钥,可以使用 ZRANGEBYSCORE $now +inf 删除过期密钥, ZREMRANGEBYSCORE -inf $now 将执行此操作 .

    在我的应用程序中,我每次查询集合时都会发出两个命令 . 我还将它与设置本身的(长)到期时间结合起来,最终清除未使用的集合 .

    This article更详细地介绍了它 .

相关问题