参考文章——简书
什么情况下expire比exists更好?
前提
- redis key过期时间必须设置(特殊需求除外),但是如果DB的值有变动会主动更新到redis,所以不会有数据不同步的情况。
场景
- 每次都需要判断某个key是否存在,然后才能执行相应的操作。
问题
- 最坏情况下,代码在执行exists时key是有效的,后面对key进行操作时,发现在那两行代码执行的中间,key被清掉了。
- 条件虽然比较极端,但是在代码里——一切皆有可能。
解决
- expire代替exists,重置key的过期时间。相当于利用expire给key续命,可以合理的“长生不死”。
过期相关补充
设置过期时间
EXPIRE <KEY> <TTL> : 将键的生存时间设为 ttl 秒
PEXPIRE <KEY> <TTL> :将键的生存时间设为 ttl 毫秒
EXPIREAT <KEY> <timestamp> :将键的过期时间设为 timestamp 所指定的秒数时间戳
PEXPIREAT <KEY> <timestamp>: 将键的过期时间设为 timestamp 所指定的毫秒数时间戳.
移除过期时间
persist key
redis值和过期时间的存储

删除book键的过期时间后的存储结构
- book键的过期时间没有了
