redis是一个广泛应用的key-value型内存数据库,和memecached一样,key是可以被设置生存周期的。 redis设置key的过期时间非常简单: SETEX mykey 10 Hello 这样就给mykey设置了10秒的生存周期。 但是当你使用了redis其他的数据结构,比如LIST,HMAP等,就没有
redis是一个广泛应用的key-value型内存数据库,和memecached一样,key是可以被设置生存周期的。
redis设置key的过期时间非常简单:
SETEX mykey 10 "Hello"
这样就给mykey设置了10秒的生存周期。
但是当你使用了redis其他的数据结构,比如LIST,HMAP等,就没有现成的命令可以使用了。不过在redis中,上面的命令本来就等效于下面两条命令
SET mykey value
EXPIRE mykey 10
HSET mykey hkey "hello" EXPIRE mykey 10
我们可以将两条命令存储为一个MULTI/EXEC存储过程,或者用支持pipline的redis客户端
下面来谈一下redis过期的key的删除机制:
不同于memcached的LAZY模式,redis对于设置了过期时间的key采用被动模式和主动模式相结合的方式:
被动模式,同memcached,当过期的key被访问时,redis会将其删除主动模式,主动模式为redis主动触发的一个以10秒为间隔的循环: 随机测试100个key的过期时间删除这100个key中所有已经过期的key如果删除了超过25个key,立刻从第一步开始重做