Redis有4个命令可以设置键的过期时间:
1. expire <key> <ttl> 设置key的生存时间为ttl秒;
2. pexpire <key> <ttk> 设置key的生存时间为ttl毫秒;
3. expireat <key> <ts> 设置key的过期时间为ts的秒数时间戳;
4. pexpireat <key> <ts> 设置key的过期时间为ts的毫秒数时间戳;
实际上 expire, pexpire, expireat 3个命令都是使用pexpireat实现的,只需要转换时间单位就行了。
redisDb结构中,有一个expires字典保存了所有key的过期时间,这个字典称之为过期字典。
typeof struct redisDb {
//...
dict *expires;
//...
} redisDb;
当一个key被设为过期后,redisDb中键空间字典和过期字典中的键重复,并不会出现重复对象,2个key指向的都是同一个对象。
key过期删除策略:
1.定时删除:设置过期键的时候,创意一个定时器;
2.惰性删除:放任过期键不管,每次访问时,判断是否过期,如过期则删除;
3.定期删除:每隔一段时间,redis会扫描过期键,发现过期则删除;
Redis实际使用的是惰性删除和定期删除2种配合使用。
定期删除函数执行步骤:
1.从一定量的数据库中去除一定数量的随机键检查,删除其中的过期键;
2.全局变量current_db会记录当前函数检查的进度,并在下一次调用时,接着上一次的进度处理。
3.随着函数不断被执行,所有过期键都会被检查到,这时将current_db变量重置为0,再开始新一轮的检查。