Redis作为缓存 - 重置到期

时间:2014-01-13 12:19:07

标签: caching redis

我使用redis作为缓存,并希望使用redis中的数据到期,这些数据不会被主动使用。目前,对象的设置到期在经过了到期时间之后删除对象。但是,如果在对象到期之前至少读取一次,我想将该对象保留在redis中。

我看到的一种方法是为每个对象存储单独的expiry_key,并将expiry_key设置为expiry_key而不是原始对象。在expiry_key上订阅del通知,当收到del通知时,检查在到期间隔期间是否至少读取一次对象(通过单独维护的访问日志)。如果未读取对象,请对原始对象执行del命令。如果已读取,则使用到期间隔重新创建expiry_key。

此实现需要额外的系统来管理到期,并且更愿意在本地使用redis。

有没有更好的解决方案来解决这个问题?

每次读取时重置对象的到期时间会增加写入redis的次数,因此这不是一种选择。

请注意,redis缓存刷新是通过更改通知系统异步管理的。

3 个答案:

答案 0 :(得分:10)

您可以在每次读取后再次设置过期密钥(在密钥上设置TTL为 O(1))。

您的系统在事务中执行此操作可能是有意义的:

MULTI
GET mykey
EXPIRE mykey 10
EXEC

您也可以管理命令。

此模式也在official documentation中描述。

答案 1 :(得分:2)

请参阅http://redis.io/topics/config

中的“将Redis配置为缓存”部分

我们可以将maxmemory-policy设置为allkeys-lru,以清除redis中的非活动内容。这适用于我所说的用例。

答案 2 :(得分:0)

另一种方法是在密钥上定义通知,然后重置它的到期

see here