抱歉不行。Redis的“容器”(即列表,哈希,集合和排序集合)不支持按成员过期,尽管过去多次要求使用此功能。
但是,您可以实现自己的逻辑以实现该结果。解决此问题的方法有几种- 这是一个示例。代替使用集合,而使用排序集合(ZSET),并使用历元值将每个成员的分数设置为到期时间。例如,可以使用Lua脚本来实现这种类型的工作流程。要添加成员,请使用以下方法:
redis.call('zadd', KEYS[1], os.time()+ARGV[1], ARGV[2])
@H_403_6@
并按照您的示例使用“ 1 a 60 1”和“ 1 a 120 2”作为参数进行评估。要实际上从集合中“过期”项目,您需要在时间过去后将其删除。您可以通过实施扫描列表的定期过程或在访问列表时进行此操作。例如,以下Lua可用于使成员过期:
redis.call('zremrangebyscore', KEYS[1], '-inf', os.time())
@H_403_6@
并根据您的示例使用“ 1 a”作为参数进行评估。
编辑:如何使用Python实现以上
import time
import redis
def add(r, key, ttl, member):
r.zadd(key, member, int(time.time()+ttl))
def expire(r, key):
r.zremrangebyscore(key, '-inf', int(time.time()))
...
r = redis.Redis()
add(r, 'a', 1, 60)
add(r, 'a', 2, 120)
# periodically or before every operation do
expire(r, 'a')
@H_403_6@