我正在使用redis作为缓存,并希望在redis中过期未被活跃使用的数据。目前,设置对象的过期时间会在过期时间过后删除对象。但是,如果在对象到期前至少读取了一次,我希望将对象保留为redis。
我看到的一种方法是为每个对象存储一个单独的expiry_key,并将过期时间设置为expiry_key而不是原始对象。订阅expiry_key上的del通知,当收到del通知时,检查对象在到期间隔期间是否至少被读取一次(通过单独维护的访问日志)。如果对象未被读取,则对原始对象执行del命令。如果已读取,则使用过期间隔重新创建expiry_key。
这种实现需要额外的系统来管理过期,并且更愿意在本地使用redis来完成。
有没有更好的解决方案?
为每次读取重置对象的过期时间会增加对redis的写入次数,因此这不是一个选择。
注意: redis缓存刷新是通过更改通知系统异步管理的。
发布于 2014-01-20 19:34:24
请参阅http://redis.io/topics/config中的“将Redis配置为缓存”一节
我们可以将maxmemory-policy设置为allkeys-lru来清除redis中的非活动内容。这将适用于我所说的用例。
发布于 2014-01-13 20:43:28
您可以在每次读取后再次设置过期密钥(在密钥上设置TTL是O(1))。
您系统在事务中执行此操作可能是有意义的:
MULTI
GET mykey
EXPIRE mykey 10
EXEC您还可以对命令进行流水线处理。
此模式也在official documentation中进行了描述。
发布于 2014-01-14 21:01:30
另一种方法是在密钥上定义一个通知,然后重置它的到期时间
see here
https://stackoverflow.com/questions/21091132
复制相似问题