Redis 的过期策略

Redis有几种不同的过期策略,用于管理键的过期和自动删除:

  1. 定时删除(TTL)
    • 最常见的过期策略是设置键的过期时间(TTL,Time To Live)。当键设置了过期时间后,Redis会在键过期时自动将其删除。可以使用 EXPIRE key seconds 或 EXPIREAT key timestamp 命令来设置键的过期时间。
  2. 惰性删除
    • Redis使用惰性删除策略来处理过期键。当客户端尝试访问一个键时,Redis会检查键是否过期,如果过期则删除它。这意味着过期键可能会在过期时间之后仍然存在一段时间,直到它被访问时才会被删除。
  3. 定期删除
    • Redis会定期地(默认每秒钟10次)随机检查一些设置了过期时间的键,删除其中已过期的键。这种策略用于辅助惰性删除,确保即使某些键未被访问,也能及时被删除。( 会再 100ms 的间隔 中默认查看 3 个 key)
  4. 内存淘汰策略
    • 当Redis内存使用达到设定的最大内存限制时(通过 maxmemory 参数设置),Redis会根据设定的内存淘汰策略删除一些键,以释放内存空间。虽然这不是严格意义上的过期策略,但它与过期策略有一定的关联,因为过期键可能被优先删除以释放空间。
相关推荐
点云SLAM7 小时前
BOOS库中Graph模块boost::edge_reverse_t和boost::vertex_color_t解读
数据库·edge·图论·bfs·dfs/拓扑排序·boost库、
尽兴-7 小时前
《深入剖析:全面理解 MySQL 的架构设计》
数据库·mysql·数据库架构设计·理解mysql架构
在风中的意志7 小时前
[数据库SQL] [leetcode] 2388. 将表中的空值更改为前一个值
数据库·sql·leetcode
梦幻通灵7 小时前
Mysql字段判空实用技巧
android·数据库·mysql
酸菜牛肉汤面9 小时前
23、varchar与char的区别
数据库
AI题库9 小时前
PostgreSQL 18 从新手到大师:实战指南 - 2.5 Serverless PostgreSQL
数据库·postgresql·serverless
IT技术分享社区9 小时前
数据库实战:MySQL多表更新JOIN操作的底层原理与性能调优指南
数据库·mysql·程序员
廋到被风吹走9 小时前
【数据库】【Oracle】分区表与大表设计
数据库·oracle
UrSpecial10 小时前
InnoDB存储引擎
数据库·mysql
gjc59210 小时前
MySQL隐蔽 BUG:组合条件查询无故返回空集?深度排查与规避方案
android·数据库·mysql·bug