redis是一个广泛应用的key-value型内存数据库,和memecached一样,key是可以被设置生存周期的。
redis设置key的过期时间非常简单:
SETEX mykey 10 "Hello"
但是当你使用了redis其他的数据结构,比如LIST,HMAP等,就没有现成的命令可以使用了。不过在redis中,上面的命令本来就等效于下面两条命令
SET mykey value
EXPIRE mykey 10
EXPIRE可以给redis内任意类型的key设置过期时间,如给HMAP类型的key设置过期时间可以用
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,立刻从第一步开始重做