Redis生存时间设置


当前第2页 返回上一页

1、volatile-lru:使用LRU算法删除一个键(设置了生存时间的键)。

2、allkey-lru:使用LRU算法删除一个键。

3、volatile-random:随即删除一个键(设置了生存时间的键)。

4、allkey-random:随即删除一个键。

5、volatile-ttl:删除生存时间即将过期的一个键。是随即取出来N个键,然后删除N个键中即将过期的键,而不是遍历所有的键删除即将过期的。N是几?配置文件配的。

6、nevication:不删除,返回错误。

Redis设置Key的过期时间 ?C EXPIRE命令

1

EXPIRE key seconds

为给定 key 设置生存时间,当 key 过期时(生存时间为 0 ),它会被自动删除。

在 Redis 中,带有生存时间的 key 被称为『易失的』(volatile)。

生存时间可以通过使用 DEL 命令来删除整个 key 来移除,或者被 SET 和 GETSET 命令覆写(overwrite),这意味着,如果一个命令只是修改(alter)一个带生存时间的 key 的值而不是用一个新的 key 值来代替(replace)它的话,那么生存时间不会被改变。

比如说,对一个 key 执行 INCR 命令,对一个列表进行 LPUSH 命令,或者对一个哈希表执行 HSET 命令,这类操作都不会修改 key 本身的生存时间。

另一方面,如果使用 RENAME 对一个 key 进行改名,那么改名后的 key 的生存时间和改名前一样。

RENAME 命令的另一种可能是,尝试将一个带生存时间的 key 改名成另一个带生存时间的another_key ,这时旧的 another_key (以及它的生存时间)会被删除,然后旧的 key 会改名为 another_key ,因此,新的 another_key 的生存时间也和原本的 key 一样。

使用 PERSIST 命令可以在不删除 key 的情况下,移除 key 的生存时间,让 key 重新成为一个『持久的』(persistent) key 。

更新生存时间

可以对一个已经带有生存时间的 key 执行 EXPIRE 命令,新指定的生存时间会取代旧的生存时间。

过期时间的精确度

在 Redis 2.4 版本中,过期时间的延迟在 1 秒钟之内 ―― 也即是,就算 key 已经过期,但它还是可能在过期之后一秒钟之内被访问到,而在新的 Redis 2.6 版本中,延迟被降低到 1 毫秒之内。

Redis 2.1.3 之前的不同之处

在 Redis 2.1.3 之前的版本中,修改一个带有生存时间的 key 会导致整个 key 被删除,这一行为是受当时复制(replication)层的限制而作出的,现在这一限制已经被修复。可用版本:

>= 1.0.0

时间复杂度:

O(1)

返回值:

设置成功返回 1 。

当 key 不存在或者不能为 key 设置生存时间时(比如在低于 2.1.3 版本的 Redis 中你尝试更新 key 的生存时间),返回 0 。

1

2

3

4

5

6

7

8

9

10

11

12

13

14

redis> SET cache_page "www.google.com"

OK

 

redis> EXPIRE cache_page 30  # 设置过期时间为 30 秒

(integer) 1

 

redis> TTL cache_page    # 查看剩余生存时间

(integer) 23

 

redis> EXPIRE cache_page 30000   # 更新过期时间

(integer) 1

 

redis> TTL cache_page

(integer) 29996

1、在小于2.1.3的redis版本里,只能对key设置一次expire。redis2.1.3和之后的版本里,可以多次对key使用expire命令,更新key的expire time。

2、redis术语里面,把设置了expire time的key 叫做:volatile keys。 意思就是不稳定的key。

3、如果对key使用set或del命令,那么也会移除expire time。尤其是set命令,这个在编写程序的时候需要注意一下。

4、redis2.1.3之前的老版本里,如果对volatile keys 做相关写入操作(LPUSH,LSET),和其他一些触发修改value的操作时,redis会删除 该key。

也就是说 :

1

2

3

4

5

redis.expire(key,expiration);

 

redis.lpush(key,field,value);

 

redis.get(key) //return null

redis2.1.3之后的版本里面没有这个约束,可以任意修改。

1

2

3

4

5

redis.set(key,100);

redis.expire(key,expiration);

redis.incr(key)

redis.get(key)

//redis2.2.2 return 101; redis<2.1.3 return 1;

5、redis对过期键采用了lazy expiration:在访问key的时候判定key是否过期,如果过期,则进行过期处理。其次,每秒对volatile keys 进行抽样测试,如果有过期键,那么对所有过期key进行处理。

更多redis知识请关注redis入门教程栏目。

以上就是Redis生存时间设置的详细内容,更多文章请关注木庄网络博客

返回前面的内容

相关阅读 >>

Redis怎么保证数据一致性

Redis雪崩和穿透的解决方法是什么

基于Redis无序集合实现禁止多端登录的方法

Redis如何实现分布式锁

Redis一般在哪里使用

Redis 中如何使用 scan 替换 keys

Redis分区实现原理介绍

Redis与memcache的区别是什么?

Redis配置文件Redis.conf超详细的解析

Redis主从复制什么时候复制

更多相关阅读请进入《Redis》频道 >>


数据库系统概念 第6版
书籍

数据库系统概念 第6版

机械工业出版社

本书主要讲述了数据模型、基于对象的数据库和XML、数据存储和查询、事务管理、体系结构等方面的内容。



打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...