redis键过期设置
EXPIRE key seconds
用来对一个键设置一个过期时间,第二个参数表示经过多少秒后键过期。 一个键过期后, 这个键将会被自动删除。 在Redis术语中,带有过期时间的键经常被称作volatile(易变的)。
当对这个键使用删除,或者覆盖操作的时候, 过期时间会被清理,这些操作包括DEL, SET,GETSET和所有的*STORE命令。而那些修改键值的命令不会修改过期时间,例如修改数值的IINCR,向队列中增加新值的LPUSH,修改hash表中的成员的HSET。
如果你只是想清除过期时间,可以调用PERSIST命令,这样这个键就不会过期。过期时间是键的一个属性,不会因为键修改名字(RENAME)而发生变化。当使用RENAME覆盖了其他键时, 只是过了一个覆盖效果,改名的键还会保留其过期时间。
注意一点:对一个键使用非正数调用EXPIRE/PEXPIRE命令,或者使用一个过去时间调用EXPIREAT/PEXPIREAT会将这个键直接移除。
更新过期时间
对一个有过期时间的键调用EXPIRE可以更新这个键的过期时间。
返回值
调用EXPIRE key seconds会返回0或者1, 0表示键不存在,1表示键已经被设置超时。
Redis如何处理带有过期时间的键
带有过期时间的键
正常情况下,redis的键是一直存在的,直到这个键被显示删除(通过DEL命令),或者因为内存限制因素被清除。对某个键设置超时时间,需要额外的内存来记录相关信息,redis会保证,当键过期时,这个键会被移除。
过期时间精度
从redis2.6开始, 过期时间的偏差在0到1毫秒之间。
过期时间逻辑
键的过期时间使用的是Unix的绝对时间戳(以毫秒作为精度),就算redis实例被关闭,到那个unix时间戳,键也会过期(只是不会立刻清理)。
如果你希望通过移动RDB文件将一个redis中的数据移动到另外一台电脑上的redis中,你需要确保这两个电脑的unix绝对时间戳一致。
如果你对键设置了过期时间,那么不要随便修改你的电脑时间,因为redis会经常检查系统时间,如果你将时间向前调整,会出现应该过期的键不过期。如果你将时间向后调整,会出现不应该过期的键过期了。
redis如何清理过期的键:
redis通过两种方式清理过期的键:被动清理和主动清理。
(1)被动清理:访问一个带有过期时间的键时,如果发现这个键已经过期了,那么就会将这个键清除。
(2)redis每秒会进行10次检查,每次检查包括:
-
从带有过期时间的键中随机选择20个,然后删除所有过期的键。
-
如果这20个中有超过25%的键已过期,那么再次执行步骤1)。
这是一个简单的概率算法,我们假设选择的键可以作为所有带过期时间的键的一个样本。通过上述操作,我们可以基本确定超时的键所占带有超时时间的键的比率小于25%. 那么因为未清理的过期的键,而多占的内存也应该小于25%.
副本(replication)和AOF文件中如何处理过期清理
为了不破坏一致性,当一个键过期清理时,DEL操作将会和AOF文件以及所有的副本节点同步。通过这种方式,过期清理操作,由主节点进行负责,从节点不会处理键的过期清理,只会等待主节点的DEL命令,这样主节点和从节点的键空间会保持一致。
栏 目:其它数据库
下一篇:Oracle SQLPlus导出数据到csv文件的方法
本文标题:redis键过期设置
本文地址:https://zz.feitang.co/shujuku/28835.html
您可能感兴趣的文章
- 12-22使用mysql记录从url返回的http GET请求数据操作
- 12-22详解sql中exists和in的语法与区别
- 12-22hive从mysql导入数据量变多的解决方案
- 12-22如何为PostgreSQL的表自动添加分区
- 12-22postgresql 实现得到时间对应周的周一案例
- 12-22sqoop export导出 map100% reduce0% 卡住的多种原因及解决
- 12-22mysql查询条件not in 和 in的区别及原因说明
- 12-22解决mysql使用not in 包含null值的问题
- 12-22解决从集合运算到mysql的not like找不出NULL的问题
- 12-22postgresql 实现多表关联删除


阅读排行
推荐教程
- 12-11mysql代码执行结构实例分析【顺序、分支、循环结构】
- 12-08添加mysql的用户名和密码是什么语句?
- 12-20PhpMyAdmin出现错误数据无法导出怎么办?
- 12-19Redis中实现查找某个值的范围
- 12-15浅析mysql迁移到clickhouse的5种方法
- 12-15CentOS7 64位下MySQL5.7安装与配置教程
- 12-14Mysql大型SQL文件快速恢复方案分享
- 12-14mysql 5.7.27 安装配置方法图文教程
- 12-13MySQL给新建用户并赋予权限最简单的方法
- 12-13关于MySQL索引的深入解析





