2014-01-13 70 views
1

我正在使用redis作为缓存,并且想要在redis中过期未使用的数据。目前,对象的设置到期会在到期时间过去后删除对象。但是,如果在对象到期之前至少读取一次,我想将对象保留在redis中。Redis作为缓存 - 重置过期

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

该实施需要额外的系统来管理过期,并希望在本地使用redis来完成。

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

为每次读取重置对象的过期将增加写入redis的次数,因此这不是一个选择。

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

回答

2

请参见“配置的Redis作为一个缓存”在http://redis.io/topics/config

我们可以设置maxmemory-政策to allkeys-lru清除来自redis的非活动内容。这将适用于我所陈述的用例。

7

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

它也许有道理为您的系统在交易中要做到这一点:

MULTI 
GET mykey 
EXPIRE mykey 10 
EXEC 

你也可以管的命令。

此模式也在official documentation中描述。

+0

嗨,Agis,感谢您的答复。我从Slave实例读取并从不同组件写入Master实例。所以,我可能无法利用交易或管道。我们可以异步写入master,但是这会增加写入redis的次数。 – vinoths

+0

@vinoths你确定这些额外的'EXPIRE'会成为一个问题吗?正如我所说的那样,他们应该对Redis毫无问题。 – Agis

0

另一种方式是做定义键上的通知,然后重置它的到期

see here