Redis掌控自身设定的过期时间
Redis是一个非常有用且流行的键值存储系统。它有一个非常特殊的功能——过期时间,这个功能可以把键值对设置一个时间限制,一旦时间到了这个键值对就会被删除。这个功能非常有用,可以当作缓存使用,提高程序的运行速度。而Redis是如何掌控自身设定的过期时间的呢?下面我们就来一起解析一下。
在Redis中设置一个过期时间非常简单,在Redis客户端中可以使用EXPIRE或者PEXPIRE命令来设置,如:
#使用EXPIRE在Redis中设置过期时间为300秒EXPIRE mykey 300#使用PEXPIRE在Redis中设置过期时间为1000毫秒PEXPIRE mykey 1000
但是Redis如何掌控自身设定的过期时间呢?Redis底层使用一个定时器来判断键值对是否过期,也就是说,Redis在内部开启了一个定时器,根据键值对的过期时间来计算它何时会过期,一旦时间到了Redis会在后台把这个键值对删除掉。
Redis底层使用的定时器是平衡二叉树实现的,这个平衡二叉树的节点被称为【过期节点】。Redis维护一个名为server.expiretrie的平衡二叉树,每个节点都包含了过期时间,以及过期键的集合。平衡二叉树中的节点是按照过期时间排好序的,最小的过期时间在最左边,而最大的过期时间在最右边。
当我们设置一个键值对的过期时间时,Redis会在平衡二叉树中插入一个新的过期节点,然后把这个节点的过期时间和对应的键添加进去。这样,每当Redis需要删除过期键值对时,它就可以从过期节点开始,按照顺序把过期时间小于等于当前时间的所有节点遍历并删除。
除了使用平衡二叉树来维护过期节点外,Redis还有一个名为server.cronloops的定时器,定期触发server.expiretrie中的过期事件。这个定时器的时间间隔很短,是一个非常小的值,以确保Redis能够快速遍历所有过期节点,同时也不至于给系统带来太大的压力。
总结一下,Redis掌控自身设定的过期时间的方式是:底层使用平衡二叉树来维护过期时间节点,同时使用一个很短的定时器来定期触发过期事件。这种方式保证了Redis对键值对的过期时间可以掌控自如,同时也不会给系统带来太大的压力。如果你正在使用Redis来做缓存,那么这个功能一定可以帮助你提高程序的运行速度。
参考代码:
import redis
import time
#连接Redis
r = redis.Redis(host=’localhost’, port=6379, db=0)
#设置一个键值对,过期时间为10秒
r.set(‘test_key’, ‘test_value’)
r.expire(‘test_key’, 10)
#获取键值对值
value = r.get(‘test_key’)
print(f”test_key: {value}”)
#等待11秒后再次获取键值对值
time.sleep(11)
value = r.get(‘test_key’)
print(f”test_key: {value}”)
输出:
test_key: b’test_value’
test_key: None
香港服务器首选树叶云,2H2G首月10元开通。树叶云(www.IDC.Net)提供简单好用,价格厚道的香港/美国云 服务器 和独立服务器。IDC+ISP+ICP资质。ARIN和APNIC会员。成熟技术团队15年行业经验。

redis可以设置生效开始的时间吗
一般是根据需求来进行设置。 redis通过expire命令来设置key的过期时间。 语法(key, expiration)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。 也就是说 (key,expiration);(key,field,value);(key) //return nullredis2.1.3之后的版本里面没有这个约束,可以任意修改。 (key,100);(key,expiration);(key)(key)//redis2.2.2 return 101; redis<2.1.3 return 1;5. redis对过期键采用了lazy expiration:在访问key的时候判定key是否过期,如果过期,则进行过期处理。 其次,每秒对volatile keys 进行抽样测试,如果有过期键,那么对所有过期key进行处理。
Redis和Memcache的区别分析
1、 Redis和Memcache都是将数据存放在内存中,都是内存数据库。 不过memcache还可用于缓存其他东西,例如图片、视频等等。 2、Redis不仅仅支持简单的k/v类型的数据,同时还提供list,set,hash等数据结构的存储。 3、虚拟内存--Redis当物理内存用完时,可以将一些很久没用到的value 交换到磁盘4、过期策略--memcache在set时就指定,例如set key1 0 0 8,即永不过期。 Redis可以通过例如expire 设定,例如expire name 105、分布式--设定memcache集群,利用magent做一主多从;redis可以做一主多从。 都可以一主一从6、存储数据安全--memcache挂掉后,数据没了;redis可以定期保存到磁盘(持久化)7、灾难恢复--memcache挂掉后,数据不可恢复; redis数据丢失后可以通过aof恢复8、Redis支持数据的备份,即master-slave模式的数据备份。
已关闭的提问还可不可以重新设置成待处理的提问??
不可以只能重新提问
发表评论