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

Redis: 内存回收

文章目录

  • 一、过期键删除策略
    • 1、惰性删除
    • 2、定时删除
    • 3、定期删除
    • 4、Redis的过期键删除策略
  • 二、内存淘汰策略
    • 1、设置过期键的内存淘汰策略
    • 2、全库键的内存淘汰策略

一、过期键删除策略

1、惰性删除

顾名思义并不是在TTL到期后就立即删除,而是在访问一个key的时候,检查该key的存活时间,如果已经过期才执行删除,并且删除的目标仅限于当前处理的键。

  • 优点:节约cpu性能,使用时发现过期键才删除。
  • 缺点:如果过期键不被访问,就不会被删除,会一直保留在内存中,存在内存泄漏的风险。

2、定时删除

创建一个定时器(timer),当将过期时立即对该键进行删除操作。

  • 优点:对内存友好,过期的键会立即删除。
  • 缺点:对CPU时间不友好,当某一时刻处在大量的键过期,那么CPU的大部分时间就会在处理删除过期键上,会对服务器的响应时间和吞吐量产生影响。

3、定期删除

每隔一段时间执行一次删除过期键操作,并通过限制执行时长和频率来减少对CPU时间的影响。

  • 难点:很难确定执行时长和频率的取值

4、Redis的过期键删除策略

使用惰性删除+定期删除策略,使得CPU时间和内存使用可以取得平衡。

二、内存淘汰策略

1、设置过期键的内存淘汰策略

  • volatile-lru
    使用LRU算法移除key,只对设置了过期时间的键(最近最少使用)。
  • volatile-random
    在过期集合中移除随机的key,只对设置了过期时间的键。
  • volatile-ttl
    移除那些TTL值最小的key,即那些最近要过期的key。

2、全库键的内存淘汰策略

  • allkeys-lru
    在所有集合key中,使用LRU算法移除key
  • allkeys-random
    在所有集合key中,移除随机的key
  • noeviction
    不进行移除,针对写操作,只返回错误信息
http://www.lryc.cn/news/338040.html

相关文章:

  • 【刷题篇】回溯算法(三)
  • pe格式从入门到图形化显示(八)-导入表
  • 如何将Paddle(Lite)模型转换为TensorFlow(Lite)模型
  • 最新Zibll子比主题V7.1版本源码 全新推出开心版
  • 响应式布局(其次)
  • arhtas idea plugin 使用手册
  • 数组算法——查询位置
  • 【解决leecode打不开的问题】使用chrome浏览器和其他浏览器均打不开leecode
  • 尝试在手机上运行google 最新开源的gpt模型 gemma
  • 56、巴利亚多利德大学、马德里卡洛斯三世研究所:EEG-Inception-多时间尺度与空间卷积巧妙交叉堆叠,终达SOTA!
  • ORA-00600: internal error code, arguments: [krbcbp_9]
  • uni-app实现分页--(2)分页加载,首页下拉触底加载更多
  • 前端工程化理解 (2024 面试题)
  • 10 Php学习:循环
  • FreeSWITCH 1.10.10 简单图形化界面17 - ubuntu22.04或者debian12 安装FreeSWITCH
  • ZStack Cloud 5.0.0正式发布——Vhost主存储、隔离PVLAN网络、云平台报警优化、灰度升级增强四大亮点简析
  • 商标没有去注册有哪些不好的影响!
  • 【小程序】常用方法、知识点汇总1
  • AugmentedReality之路-平面检测(5)
  • MQ:延迟队列
  • Element ui 动态展示表格列,动态格式化表格列的值
  • xxl-job调度任务原理解析
  • 实验2 路由器基本配置
  • docker部署安装整理
  • 为什么你明明拥有5年开发经验,但是依然写不出来一份简历?
  • 【ZZULIOJ】1062: 最大公约数(Java)
  • 北斗导航 | ARAIM算法的原理和性能测试
  • elasticsearch7安全配置--最低安全等级,用户名密码
  • 项目架构MVC,DDD学习
  • SQLite的PRAGMA 声明