Redis过期键删除策略解读

2025-01-16 04:50

本文主要是介绍Redis过期键删除策略解读,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

《Redis过期键删除策略解读》Redis通过惰性删除策略和定期删除策略来管理过期键,惰性删除策略在键被访问时检查是否过期并删除,节省CPU开销但可能导致过期键滞留,定期删除策略定期扫描并删除过期键,...

1.Redis使用两种不同的策略来删除过期键,分别是惰性删除策略和定期删除策略

1.1惰性删除策略

当一个过期键被访问时,Redis会检查这个China编程键是否过期。如果过期,就会立即删除。如果没有过期,Redis会像处理普通键一样继续处理它。这种方式被称为惰性删除,因为Redis只会在需要访问一个键时才会检查android它是否过期,并在发现它过期后删除它。这种策略的好处是能够节省删除键所带来的 CPU 开销,因为 Redis 只有在有需要时才会删除键

1.2定期删除策略

Redis也使用一种定期删除策略来删除过期键。在这种策略下,Redis会每隔一段时间扫描数据库,查找所有已过期的键并将它们删除。这种方式称为定期删除,因为Redis会定期执行这个操作。这种策略的好处是能够保证 Redis 数据库中过期的键能够及时被删除,从而避免浪费空间。

1.3策略小结

Redis 的默认配置是同时使用惰性删除和定期删除两种策略。当 Redis 同时使用这两种策略时,惰性删除策略能够节省 CPU 开销,定期删除策略能够保证过期键及时被删除。

在一些特殊情况下,我们可能需要调整 Redis 的删除策略,比如对于一些不太重要的数据,我们可以只使用惰性删除策略来降低 Redis 的 CPU 开销,对于一些比较重要的数据,我们可以只使用定期删除策略来保证数据的正确性。这些调整可以通过 Redis 的配置参数来实现。

惰性删除策略可以让Redis更高效地使用内存,因为它只有在需要访问一个键时才会检查它是否过期。但是,它可能会导致过期键长时间滞留在内存中,直到下次被访问。定期删除策略则可以保证过期键及时被删除,但可能会对性能产生一定的影响,因为它需要周期性地遍历整个数据库。为了平衡内存使用和性能,Redis通常会同时使用这两种策略。

2.惰性删除策略与定期删除策略的使用

Redis 的惰性删除策略和定期删除策略默认都是开启的,所以在通常情况下,我javascript们不需要做任何特殊的配置即可使用这两js种策略。

如果你想要对 Redis 的删除策略进行调整,可以通过以下方式进行配置:

惰性删除策略

Redis 的惰性删除策略是默认开启的,如果你想要关闭惰性删除,可以在 Redis 的配置文件中将以下参数设置为 no:

# 是否启用惰性删除
# 如果设置为 no,则 Redis 将不使用惰性删除策略
# 默认为 yes
lazyfree-lazy-eviction no

定期删除策略

Redis 的定期删除策略是通过一个配置参数来控制的,这个参数默认值为 10 秒钟,即 RkNaonfVdXcedis 每隔 10 秒钟会检查一次过期键并删除过期键。如果你想要改变这个值,可以在 Redis 的配置文件中修改以下参数:

# 设置 Redis 定期删除策略的周期
# 默认为 10 秒钟
# 单位为秒
hz 100

在上面的配置中,我们将 Redis 定期删除策略的周期设置为 100 秒,即 Redis 每隔 100 秒钟会检查一次过期键并删除过期键。

需要注意的是,当 Redis 同时使用惰性删除和定期删除两种策略时,惰性删除策略会优先执行,即 Redis 只有在有客户端请求键时才会检查键是否过期,定期删除策略只有在惰性删除策略无法满足时才会起作用。

3.为什么Redis中会导致读取到过期数据

虽然定期删除策略可以释放一些内存,但是,Redis 为了避免过多删除操作对性能产生影响,每次随机检查数据的数量并不多。如果过期数据很多,并且一直没有再被访问的话,这些数据就会留存在 Redis 实例中。业务应用之所以会读到过期数据,这些留存数据就是一个重要因素。

惰性删除策略实现后,数据只有被再次访问时,才会被实际删除。如果客户端从主库上读取留存的过期数据,主库会触发删除操作,此时,客户端并不会读到过期数据。但是,从库本身不会执行删除操作,如果客户端在从库中访问留存的过期数据,从库并不会触发数据删除。

4.从库会给客户端返回过期数据吗?

Redis3.2版本之前,从库会返回过期数据。Redis3.2之后从库不会返回过期数据,会返回空值,但是还是有可能会读到。

如果使用的是 Redis 3.2 之前的版本,那么,从库在服务读请求时,并不会判断数据是否过期,而是会返回过期数据。在 3.2 版本后,Redis 做了改进,如果读取的数据已经过期了,从库虽然不会删除,但是会返回空值,这就避免了客户端读到过期数据。所以,在应用主从集群时,尽量使用 Redis 3.2 及以上版本。

使用了 Redis 3.2 后的版本,还是会读到过期数据,这跟 Redis 用于设置过期时间的命令有关系,有些命令给数据设置的过期时间在从库上可能会被延后,导致应该过期的数据又在从库上被读取到

4.1设置数据过期时间命令说明

  1. EXPIRE 和 PEXPIRE:它们给数据设置的是从命令执行时开始计算的存活时间;
  2. EXPIREAT 和 PEXPIREAT:它们会直接把数据的过期时间设置为具体的一个时间点。

主从库全量同步,收到EXPIRE命令,主库直接执行,全量同步完成发送给从库,从库执行的时候会在当前时间基础上加上存活时间,过期时间明显延后。

为了避免这种情况,在业务应用中使用 EXPIREAT/PEXPIREAT 命令,把数据的过期时间设置为具体的时间点,避免读到过期数据

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持编程China编程(www.chinasem.cn)。

这篇关于Redis过期键删除策略解读的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1153080

相关文章

docker如何删除悬空镜像

《docker如何删除悬空镜像》文章介绍了如何使用Docker命令删除悬空镜像,以提高服务器空间利用率,通过使用dockerimage命令结合filter和awk工具,可以过滤出没有Tag的镜像,并将... 目录docChina编程ker删除悬空镜像前言悬空镜像docker官方提供的方式自定义方式总结docker

Deepseek使用指南与提问优化策略方式

《Deepseek使用指南与提问优化策略方式》本文介绍了DeepSeek语义搜索引擎的核心功能、集成方法及优化提问策略,通过自然语言处理和机器学习提供精准搜索结果,适用于智能客服、知识库检索等领域... 目录序言1. DeepSeek 概述2. DeepSeek 的集成与使用2.1 DeepSeek API

Redis的数据过期策略和数据淘汰策略

《Redis的数据过期策略和数据淘汰策略》本文主要介绍了Redis的数据过期策略和数据淘汰策略,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录一、数据过期策略1、惰性删除2、定期删除二、数据淘汰策略1、数据淘汰策略概念2、8种数据淘汰策略

修改若依框架Token的过期时间问题

《修改若依框架Token的过期时间问题》本文介绍了如何修改若依框架中Token的过期时间,通过修改`application.yml`文件中的配置来实现,默认单位为分钟,希望此经验对大家有所帮助,也欢迎... 目录修改若依框架Token的过期时间修改Token的过期时间关闭Token的过期时js间总结修改若依

SpringBoot中的404错误:原因、影响及解决策略

《SpringBoot中的404错误:原因、影响及解决策略》本文详细介绍了SpringBoot中404错误的出现原因、影响以及处理策略,404错误常见于URL路径错误、控制器配置问题、静态资源配置错误... 目录Spring Boot中的404错误:原因、影响及处理策略404错误的出现原因1. URL路径错

Redis存储的列表分页和检索的实现方法

《Redis存储的列表分页和检索的实现方法》在Redis中,列表(List)是一种有序的数据结构,通常用于存储一系列元素,由于列表是有序的,可以通过索引来访问元素,因此可以很方便地实现分页和检索功能,... 目录一、Redis 列表的基本操作二、分页实现三、检索实现3.1 方法 1:客户端过滤3.2 方法

使用Python在Excel中插入、修改、提取和删除超链接

《使用Python在Excel中插入、修改、提取和删除超链接》超链接是Excel中的常用功能,通过点击超链接可以快速跳转到外部网站、本地文件或工作表中的特定单元格,有效提升数据访问的效率和用户体验,这... 目录引言使用工具python在Excel中插入超链接Python修改Excel中的超链接Python

MySQL中的MVCC底层原理解读

《MySQL中的MVCC底层原理解读》本文详细介绍了MySQL中的多版本并发控制(MVCC)机制,包括版本链、ReadView以及在不同事务隔离级别下MVCC的工作原理,通过一个具体的示例演示了在可重... 目录简介ReadView版本链演示过程总结简介MVCC(Multi-Version Concurr

关于Gateway路由匹配规则解读

《关于Gateway路由匹配规则解读》本文详细介绍了SpringCloudGateway的路由匹配规则,包括基本概念、常用属性、实际应用以及注意事项,路由匹配规则决定了请求如何被转发到目标服务,是Ga... 目录Gateway路由匹配规则一、基本概念二、常用属性三、实际应用四、注意事项总结Gateway路由

Python中操作Redis的常用方法小结

《Python中操作Redis的常用方法小结》这篇文章主要为大家详细介绍了Python中操作Redis的常用方法,文中的示例代码简洁易懂,具有一定的借鉴价值,有需要的小伙伴可以了解一下... 目录安装Redis开启、关闭Redisredis数据结构redis-cli操作安装redis-py数据库连接和释放增