上一篇我们讲了 Redis 内存用完之后的内存淘汰策略,它主要是用来出来异常情况下的数据清理,而本文讲的是 Redis 的键值过期之后的数据处理,讲的是正常情况下的数据清理,但面试者常常会把两个概念搞混,以至于和期望的工作失之交臂。我们本文的职责之一就是帮读者朋友搞清楚二者的区别,相信看完本文你就会对二者的概念有一个本质上的认识。
我们本文的面试题是,Redis 如何处理已过期的数据?
典型回答
在 Redis 中维护了一个过期字典,会将所有已经设置了过期时间的键值全部存储到此字典中,例如我们使用设置过期时间的命令时,命令如下:
127.0.0.1:6379> set mykey java ex 5
OK
此命令表示 5s 之后键值为 mykey:java
的数据将会过期,其中 ex
是 expire
的缩写,也就是过期、到期的意思。
过期时间除了上面的那种字符类型的直接设置之外,还可以使用 expire key seconds
的方式直接设置,示例如下:
127.0.0.1:6379> set key value
OK
127.0.0.1:6379> expire key 100 # 设置 100s 后过期
(integer) 1
获取键值的执行流程是,当有键值的访问请求时 Redis 会先判断此键值是否在过期字典中,如果没有表示键值没有设置过期时间(永不过期),然后就可以正常返回键值数据了;如果此键值在过期字典中则会判断当前时间是否小于过期时间,如果小于则说明此键值没有过期可以正常返回数据,反