redis进阶: 过期删除策略

栏目: 数据库 · 发布时间: 7年前

内容简介:讲到redis的过期删除策略,就不得不说一下redis是如何判断键是否过期,让我们首先来了解下redis内部结构是如何存储键与过期时间之间的关系在过期字典dict的键是一个指针,指向键对象;值是一个long long类型的整数,保存了其键的过期时间(毫秒精度的UNIX时间戳)

讲到 redis 的过期删除策略,就不得不说一下redis是如何判断键是否过期,让我们首先来了解下redis内部结构是如何存储键与过期时间之间的关系

过期字典

redisServer 结构中存储着一个 expires 字典(key-value),专门用来存储过期时间,如下所示:

typedef struct redisDb {
    // 字典类型,用于保存键的过期时间
    dict *expires;
} redisDb;

过期字典dict的键是一个指针,指向键对象;值是一个long long类型的整数,保存了其键的过期时间(毫秒精度的UNIX时间戳)

因为是字典类型key-value,所以查询的时间复杂度为 O(1) ,当我们需要判断redis的键是否过期时,只需要从过期字典里面取出键所对应的值,如果键不存在,则表示没有过期;如果键存在,则判断值与当前的时间戳的大小,大于当前时间戳则不过期,小于则过期;

现在让我们来谈谈redis删除策略

删除策略

redis有三种过期删除策略: 定时删除惰性删除定期删除

  1. 定时删除:在设置键的过期时间的同时,创建timer定时器,当键快过期时执行删除操作

  2. 惰性删除:当每次获取键时,检查获取的键是否过期,如果过期则删除该键

  3. 定期删除 :每隔一段时间,redis就会对数据库进行一次检查,删除里面的过期键

优缺点

这三种过期删除策略的优缺点如下:

策略 优点 缺点
定时删除 对内存友好,因为总是能及时删除过期键 对CPU不友好,因为过期键较多的情况可能发生同时删除过期键导致占用太多CPU时间
惰性删除 对内存不友好,因为如果键过期了,但是没有被访问到,那么就会一直存在于内存中,导致内存占用 对CPU友好,因为只有当被访问到才会执行过期判断与删除
定期删除 折中,跟删除操作的执行时长与频率有关 折中,跟删除操作的执行时长与频率有关

由此可知,三种过期删除策略都有各自的优缺点,而定期删除是定时删除与惰性删除的折中方案

目前redis服务器采用的是惰性删除与定期删除两种策略,通过配合使用更好地保证CPU时间与内存的平衡

happy coding!

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

创新者

创新者

[美] 沃尔特 · 艾萨克森 / 关嘉伟、牛小婧 / 中信出版社 / 2016-6 / 88.00

讲述了计算机和互联网从无到有的发展历程,并为我们生动地刻画出数字时代的创新者群像。 在近200年的数字化进程中群星闪耀,艾萨克森从一个计算机程序的创造者、诗人拜伦之女埃达说起,细数了这一群站在科学与人文交叉路口的创新者,他们包括通用型电子计算机的创造者奠奇利、科学家冯·诺依曼、仙童半导体公司的“八叛逆”、天才图灵、英特尔的格鲁夫、微软的比尔·盖茨、苹果公司的乔布斯、谷歌的拉里·佩奇等。《创新......一起来看看 《创新者》 这本书的介绍吧!

XML 在线格式化
XML 在线格式化

在线 XML 格式化压缩工具

html转js在线工具
html转js在线工具

html转js在线工具

UNIX 时间戳转换
UNIX 时间戳转换

UNIX 时间戳转换