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次检查,每次检查包括:

  1)从带有过期时间的键中随机选择20个,然后删除所有过期的键。

  2)如果这20个中有超过25%的键已过期,那么再次执行步骤1)。

这是一个简单的概率算法,我们假设选择的键可以作为所有带过期时间的键的一个样本。通过上述操作,我们可以基本确定超时的键所占带有超时时间的键的比率小于25%. 那么因为未清理的过期的键,而多占的内存也应该小于25%.

副本(replication)和AOF文件中如何处理过期清理

为了不破坏一致性,当一个键过期清理时,DEL操作将会和AOF文件以及所有的副本节点同步。通过这种方式,过期清理操作,由主节点进行负责,从节点不会处理键的过期清理,只会等待主节点的DEL命令,这样主节点和从节点的键空间会保持一致。

redis键过期 (redis 2.6及以上)的更多相关文章

  1. springboot使用Redis,监听Redis键过期的事件设置与使用代码

    我使用的是Windows下的Redis服务,所以一下Redis设置都是在Windows平台进行. 1.修改Redis配置文件 1.1:Windows下的Redis存在两个配置文件 修改带有servic ...

  2. 一文详解Redis键过期策略

    摘要:Redis采用的过期策略:惰性删除+定期删除. 本文分享自华为云社区<Redis键过期策略详解>,作者:JavaEdge. 1 设置带过期时间的 key # 时间复杂度:O(1),最 ...

  3. redis键过期时间

    redis服务器中每个数据库都是一个redisDb,而redisDb实质上是一个字典的模型,数据库的每一个键都是一个字典的键值,对数据库的增删改查也就是对字典对象的增删改查. redis在维护带有过期 ...

  4. 【Redis】过期键删除策略和内存淘汰策略

    Redis 过期键策略和内存淘汰策略 目录 Redis 过期键策略和内存淘汰策略 设置Redis键过期时间 Redis过期时间的判定 过期键删除策略 定时删除 惰性删除 定期删除 Redis过期删除策 ...

  5. 4.redis 键

    转自:http://www.runoob.com/redis/redis-tutorial.html Redis 键(key) Redis 键命令用于管理 redis 的键. 语法 Redis 键命令 ...

  6. Redis键管理

    Redis键管理 Redis 键命令用于管理 redis 的键. 语法 Redis 键命令的基本语法如下: redis > COMMAND KEY_NAME redis > SET w3c ...

  7. Redis 键(key)相关的命令及其它命令的查看地址

    Redis 键(key) Redis 键命令用于管理 redis 的键. 语法 Redis 键命令的基本语法如下: redis 127.0.0.1:6379> COMMAND KEY_NAME ...

  8. Redis附加功能之键过期功能

    一.键过期功能的相关命令 二.设置生存时间 Redis 提供了两个命令来设置键的生存时间(TTL,time to live),它们分别是: 如果给定的键不存在,那么 EXPIRE 和 PEXPIRE ...

  9. python中的Redis键空间通知(过期回调)

    介绍 Redis是一个内存数据结构存储库,用于缓存,高速数据摄取,处理消息队列,分布式锁定等等. 使用Redis优于其他内存存储的优点是Redis提供持久性和数据结构,如列表,集合,有序集和散列. 在 ...

随机推荐

  1. thinkphp5---安装到宝塔出现Warning: require(): open_basedir错误

    使用thinkphp5安装到宝塔的linux上,出现以下错误: Warning: require(): open_basedir restriction in effect. File(/www/ww ...

  2. iostat vmstat

    iostat https://linux.die.net/man/1/iostat https://www.geeksforgeeks.org/iostat-command-in-linux-with ...

  3. java生成订单编号

    随着项目用户数量的扩大,高并发随之而来.那么如何在当前系统生成唯一编号呢? 一台数据库可以用自增,集群呢?当然也有随之的解决方案,但是最好的还是在项目生成了唯一的编号再插入到数据库.而不是数据库插入了 ...

  4. 【翻译】Flink Table Api & SQL —Streaming 概念 —— 表中的模式匹配 Beta版

    本文翻译自官网:Detecting Patterns in Tables Beta  https://ci.apache.org/projects/flink/flink-docs-release-1 ...

  5. [LeetCode] 273. Integer to English Words 整数转为英文单词

    Convert a non-negative integer to its english words representation. Given input is guaranteed to be ...

  6. LeetCode:四数之和【18】

    LeetCode:四数之和[18] 题目描述 给定一个包含 n 个整数的数组 nums 和一个目标值 target,判断 nums 中是否存在四个元素 a,b,c 和 d ,使得 a + b + c ...

  7. mongoDB主从和集群

    主从(windows下的配置) 主服务器设置 mongod --dbpath=F:\mongoDB\db --master \\dbpath是设定数据存放路径 --master是指定为主库 从服务器设 ...

  8. SQL死锁情况汇总排查

    select dbname,entity_name,count(1) as locks from (SELECT request_session_id AS spid, DB_NAME(resourc ...

  9. VS+OpenGl 显示三维STL模型 代码

    今天调出了用VS环境结合OpenGL glut工具包进行显示STL模型的模块,进行了渲染.效果: 如下,后期会进行进一步优化,先贴上: #ifndef DATA_H #define DATA_H st ...

  10. Django-01-Web框架简介

    1. 什么是web框架 框架,即framework,特指为解决一个开放性问题而设计的具有一定约束性的支撑结构,使用框架可以帮你快速开发特定的系统,简单地说,就是你用别人搭建好的舞台来做表演. 对于所有 ...