谈谈Redis的过期数据删除策略

目录

前言

定时删除 

惰性删除

定期删除 

总结


前言

我们都知道Redis 所有的数据结构都可以设置过期时间,时间一到,这些数据就会变成过期数据,这个时候就需要进行删除,这里需要注意一下,这个与淘汰策略不同,淘汰策略是指当内存被占满了之后,这时就有必要将一些数据清理淘汰掉。

Redis提供了四个命令来设置过期时间:

  • EXPIRE <key> <ttl> :表示将键 key 的生存时间设置为 ttl 秒。
  • PEXPIRE <key> <ttl> :表示将键 key 的生存时间设置为 ttl 毫秒。
  • EXPIREAT <key> <timestamp> :表示将键 key 的生存时间设置为 timestamp 所指定的秒数时间戳。
  • PEXPIREAT <key> <timestamp> :表示将键 key 的生存时间设置为 timestamp 所指定的毫秒数时间戳。

还有一些与之相关的命令如下: 

  •  PERSIST <key> :表示将key的过期时间移除。
  • TTL <key> :以秒的单位返回键 key 的剩余生存时间。
  • PTTL <key> :以毫秒的单位返回键 key 的剩余生存时间。
指令结果状态
XX具有时效性的数据
-1永久有效的数据
-2已经过期的数据 或 被删除的数据 或 未定义的数据

 在redis中有3种过期数据删除策略:惰性删除和定期删除及定时删除

数据删除策略目标:在内存占用与CPU占用之间寻找一种平衡,顾此失彼都会造成整体redis性能的下降,甚至引发服务器宕机或内存泄露

定时删除 

定时删除对每个设置过期时间的key都需要创建一个定时器,到过期时间就会立即对key进行清除。

优点:立即删除能保证内存中数据的最大新鲜度,因为它保证过期键值会在过期后马上被删除,其所占用的内存也会随之释放。对内存来说是非常友好的。

缺点:  立即删除对cpu是最不友好的。因为删除操作会占用cpu的时间,如果刚好碰上了cpu很忙的时候,比如正在做交集或排序等计算的时候,就会给cpu造成额外的压力。

惰性删除

惰性删除不会去主动删除数据,而是在访问数据的时候,再检查当前键值是否过期,如果过期则执行删除并返回 null 给客户端,如果没有过期则返回正常信息给客户端。 

优点:对 CPU友好,我们只会在使用该键时才会进行过期检查,对于很多用不到的key不用浪费时间进行过期检查。

缺点:内存泄漏,就是一个键已经过期,如果我们一直不去访问它,然后的话让这个键仍然保留在redis中,也就是意味着这个过期键不被删除,它所占用的内存就不会释放。因此对于内存是很不友好的, 除非我们手动执行FLUSHDB(用于清空当前数据库中的所有 key)。

定期删除 

定期删除策略每隔一段时间执行一次删除过期键操作并通过限制删除操作执行时长和频率来减少删除操作对CPU时间的影响。定时任务的发起的频率由redis.conf配置文件中的hz来进行配置,Redis 默认每 1 秒运行 10 次,也就是每 100 ms 执行一次,每次随机抽取一些设置了过期时间的 key(这边注意不是检查所有设置过期时间的key,而是随机抽取部分),检查是否过期,如果发现过期了就直接删除。建议不要将这个值(hz)设置超过 100,否则会对CPU造成比较大的压力。

 定期清理的两种模式:

  • SLOW模式是定时任务,执行频率默认为10hz,每次不超过25ms,以通过修改配置文件redis.conf 的 hz 选项来调整这个次数
  • FAST模式执行频率不固定,每次事件循环会尝试执行,但两次间隔不低于2ms,每次耗时不超过1ms

定期删除注意事项:

  • 如果删除操作执行次数过多、执行时间太长,就会导致占用大量cpu资源去进行删除操作
  • 如果删除操作次数太少、执行时间短,就会导致内存资源被持续占用,得不到释放。

优点:可以通过限制删除操作执行的时长和频率来减少删除操作对 CPU 的影响。另外定期删除,也能有效释放过期键占用的内存。

缺点:难以确定删除操作执行的时长和频率。 

总结

删除策略特点对CPU资源总结
定时删除节约内存,无占用不分时段占用CPU资源,频度高拿时间换空间
惰性删除内存占用严重延时执行,CPU利用率高拿空间换时间
定期删除内存定期随机清理每秒花费固定的CPU资源维护内存随机抽查,重点抽查
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
### 回答1: Redis过期数据删除策略主要有两种:惰性删除和定期删除。 惰性删除是指在Redis中,当一个键过期后,它并不会立即被删除,而是在客户端尝试访问这个键时,Redis会检查这个键是否过期,如果过期了,就会删除这个键。这种策略的优点是可以节省内存空间,缺点是可能会导致过期键在一段时间内一直存在于内存中,占用内存空间。 定期删除是指Redis会定期地扫描数据库中的键,删除已经过期的键。这种策略的优点是可以保证过期键及时被删除,缺点是会占用一定的CPU资源和IO资源。 在Redis中,可以通过配置文件中的"maxmemory-policy"选项来选择过期数据删除策略,常用的策略有noeviction(不删除任何数据)、volatile-lru(删除最近最少使用的过期键)、volatile-ttl(删除最近过期的键)、allkeys-lru(删除最近最少使用的键,包括过期和未过期的键)等。 ### 回答2: Redis过期数据删除策略主要有以下几种: 1. 定期删除策略Redis会在指定的时间间隔内,随机抽取一部分过期的键进行删除。这种策略的优点是简单高效,适用于大多数的应用场景。 2. 惰性删除策略:当用户访问一个过期键时,Redis会检测该键是否过期,如果过期就会立即删除。这种策略的优点是内存占用小,不会影响正常的读写性能。 3. 定期和惰性删除策略的结合:Redis会使用定期删除策略进行过期键的删除,同时在用户访问过期键时进行惰性删除。这种策略的优点是兼具定期删除和惰性删除的优点,能够更加高效地处理过期键。 总体来说,Redis过期数据删除策略主要侧重于通过定期删除和惰性删除两种方式来实现过期数据的清理,以保证Redis的内存使用效率和读写性能。用户可以根据具体的应用场景和需求选择合适的删除策略。 ### 回答3: Redis有三种删除策略来处理过期数据: 1. 惰性删除:当客户端尝试读取一个已过期的键时,Redis删除该键并返回空值。这种方式是最简单的删除策略,但可能会导致较长时间的延迟,因为删除操作是在访问发生时触发的。 2. 定期删除Redis会每隔一段时间,检查部分设置了过期时间的键,并删除其中已过期的键。默认情况下,Redis每秒检查十个随机键。通过设置`config`中的`hz`参数来调整检查频率。这种策略可以保证过期键的及时删除,但也会产生一定的系统开销。 3. 延迟删除(LRU算法):Redis将每个键上的过期时间都记录在一个全局的列表中,并按照时间顺序对这个列表进行排序。当内存不足或者达到最大内存限制时,Redis会从列表的最开头开始逐个检查键,并删除其中已过期的键。这种策略能够有效地回收内存,但可能导致删除操作的延迟。 这些删除策略可以根据具体的业务需求进行选择和调整。具体选择哪种策略取决于应用对内存和延迟的要求。例如,如果对内存比较敏感,可以使用定期删除或延迟删除策略;如果对延迟比较敏感,可以使用惰性删除策略

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

一个风轻云淡

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值