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会根据设定的内存淘汰策略删除一些键,以释放内存空间。虽然这不是严格意义上的过期策略,但它与过期策略有一定的关联,因为过期键可能被优先删除以释放空间。
相关推荐
BS_Li10 分钟前
【Linux系统编程】进程控制
java·linux·数据库
多多*11 分钟前
分布式中间件 消息队列Rocketmq 详解
java·开发语言·jvm·数据库·mysql·maven·java-rocketmq
z***677720 分钟前
postgresql链接详解
数据库·postgresql
v***913024 分钟前
MYSQL的第一次
数据库·mysql
麦兜*27 分钟前
Redis在Web3中的应用探索:作为链下状态缓存与索引层
java·spring boot·redis·spring cloud·缓存·docker·web3
施嘉伟28 分钟前
解决 Oracle 11g Data Guard ORA-16047 的实战经验
数据库·oracle
启明真纳28 分钟前
用 Logstash 把 PostgreSQL 数据实时导出到 Kafka
数据库·postgresql·kafka
百***349532 分钟前
Python连接SQL SEVER数据库全流程
数据库·python·sql
2501_9411114033 分钟前
使用Fabric自动化你的部署流程
jvm·数据库·python
Violet_YSWY41 分钟前
我就用mybatis作为与数据库交互,但我想用orm,最好的实现方案是啥
数据库·mybatis·交互