当前位置: 首页 > news >正文

【redis使用场景——缓存——数据过期策略 】

redis使用场景——缓存——数据过期策略

  • 定期删除(Active Expiration)
    • 1. 快速模式(Fast Expiration Cycle)
      • 工作流程:
      • 特点:
      • 优点:
    • 2. 慢速模式(Slow Expiration Cycle)
      • 工作流程:
      • 特点:
      • 优点:
  • 惰性删除(Lazy Expiration)
    • 特点:
  • redis的过期删除策略

定期删除(Active Expiration)

Redis 会定期(默认每秒 10 次)随机抽取一些设置了过期时间的 key,检查它们是否过期,如果过期就删除。

1. 快速模式(Fast Expiration Cycle)

工作流程:

  • Redis 每次事件循环(event loop)都会执行快速过期检查

  • 从设置了过期时间的键中随机抽取 20 个进行检查

  • 删除其中已过期的键

  • 如果发现超过 25% 的键已过期,则立即再抽取 20 个进行检查(循环直到低于 25%)

特点:

  • 执行频率高(每秒执行多次)

  • 每次检查的键数量少

  • 执行时间短(不超过 1ms)

  • 主要处理即将过期的键

优点:

  • 对系统性能影响小
  • 能及时清理大部分过期键

2. 慢速模式(Slow Expiration Cycle)

工作流程:

  • 按数据库逐个检查(Redis 默认有 16 个数据库)
  • 从过期字典(expires字典)中随机抽取键进行检查
  • 默认每次扫描 20 个键
  • 如果发现超过 25% 的键已过期,则继续扫描
  • 每次慢速模式的总执行时间不超过 hz 配置的 25%(默认 hz=10,即 25ms)

特点:

  • 执行频率低(默认每秒 1 次)
  • 每次检查的键数量多
  • 执行时间较长(可配置,默认不超过 25ms)
  • 全面扫描所有过期键

优点:

  • 能清理更多过期键
  • 防止大量键堆积过期

惰性删除(Lazy Expiration)

当客户端尝试访问一个 key 时,Redis 会先检查该 key 是否设置了过期时间,如果已过期则立即删除并返回空。

特点:

只有在访问时才会检查过期,对不常访问的 key,即使过期也可能长时间占用内存

redis的过期删除策略

惰性删除+定期删除两种策略进行配合使用

http://www.lryc.cn/news/575709.html

相关文章:

  • 新手向:Neo4j的安装与使用
  • CTF:PHP 多关卡绕过挑战
  • Flink部署与应用——Flink架构概览
  • 国外开源客服系统chathoot部署,使用教程
  • 信息化系统流程管理模块,企业高价值资产的跨省/市运输审批流程的功能
  • 网络安全之SQL RCE漏洞
  • AI 口语陪练:教育领域的新变革​
  • AI智能体——OpenManus 源码学习
  • 使用 ReAct 框架在 Ollama 中实现本地代理(Agent)
  • Docker安装Mysql、配置文件挂载、修改Mysql编码
  • Python-7-读取/写入文件数据
  • Rust与Go:GAN实战对决
  • 合规型区块链RWA系统解决方案报告——机构资产数字化的终极武器
  • SQL语句在MySQL中的执行过程
  • python pyecharts 数据分析及可视化
  • Python 将文件夹中的所有文件打包成Zip压缩包
  • easyExcel导入多sheet的Excel,存在合并单元格、列不固定的情况
  • 超实用AI工具分享——ViiTor AI视频配音功能教程(附图文)
  • html 照片环 - 图片的动态3D环绕
  • 渗透实战:使用隐式转换覆盖toString的反射型xss
  • Linux 统一方式安装多版本 JDK 指南
  • python基于协同过滤的动漫推荐系统
  • CSP-J 2021 入门级 第一轮(初赛) 阅读程序(1)
  • CSMA/CD相关习题---谢希仁课后题
  • 数据分享:医学数据集-糖尿病数据集
  • Git 使用规范与命令使用场景详解
  • 与 AI 聊天更顺畅:cat_code.py
  • MIT 6.824学习心得(1) 浅谈分布式系统概论与MapReduce
  • 【全志V821_FoxPi】3-2 Linux 5.4 SPI + XPT2046触摸(ADS7846) + tslib
  • 基于SpringBoot和Leaflet的区域冲突可视化-以伊以冲突为例