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

整理好了!2024年最常见 20 道 Redis面试题(九)

上一篇地址:整理好了!2024年最常见 20 道 Redis面试题(八)-CSDN博客

十七、Redis 的过期策略有哪些?

Redis 的过期策略主要有三种:

  1. 定时删除:当为一个键设置了过期时间后,Redis 会创建一个定时器。当定时器到达过期时间时,Redis 会自动执行删除操作。这种方式的优点是能够保证内存被尽快释放,但缺点是如果过期的键非常多,删除这些键会占用大量的 CPU 时间,可能会影响到服务器的响应时间和吞吐量。

  2. 惰性删除:Redis 不会在键过期时立即删除它,而是在每次访问该键时进行检查,如果发现键已过期,则进行删除操作。这种方式的优点是对 CPU 比较友好,因为只有在访问键时才会检查和删除过期键,因此不会占用太多的系统资源。不过,缺点是如果一个键过期后长时间未被访问,它所占用的内存将不会被释放,可能导致内存泄露。

  3. 定期删除:Redis 会定期执行删除操作,随机检查一定数量的键,并删除其中的过期键。这种方式的优点是可以在一定程度上限制删除操作对 CPU 的影响,并且能够删除过期数据以减少对内存的无效占用。不过,它的缺点是在内存清理方面不如定时删除,同时在 CPU 时间友好方面不如惰性删除。

实际上,Redis 采用的是惰性删除和定期删除的组合策略,以在 CPU 和内存使用之间取得平衡。在 Redis 4.0 版本之后,还引入了 lazyfree-lazy-expire 参数,允许异步删除过期键,进一步优化了性能。此外,Redis 的过期字典用于存储所有键的过期时间,使得过期键的查找和删除更加高效。

十八、Redis 的 LRU 缓存淘汰策略是如何工作的?

Redis 的 LRU(Least Recently Used,最近最少使用)缓存淘汰策略是一种基于数据访问模式的内存淘汰机制,用于在内存达到限制时决定哪些数据应该被删除。以下是 LRU 策略在 Redis 中的工作原理:

  1. 数据访问记录:Redis 维护了一个内部的数据结构,通常是链表,用于记录每个键的访问顺序。当一个键被访问时,它会被移动到链表的头部,表示最近被访问过。

  2. 内存限制:Redis 配置中有一个 maxmemory 选项,用于设置最大内存使用量。当 Redis 的内存使用量达到这个限制时,会触发内存淘汰策略。

  3. 淘汰过程

    • 当 Redis 需要为新数据腾出空间时,它会根据 LRU 策略检查链表中的键。
    • 链表尾部的键表示最长时间没有被访问过,因此它们是被淘汰的首选。
    • Redis 会从链表尾部开始,逐个检查并删除这些键,直到腾出足够的空间。
  4. 配置选项:Redis 提供了不同的内存淘汰策略配置选项,allkeys-lru 是其中之一,它表示在所有键中使用 LRU 策略进行淘汰。此外,还有 volatile-lru,它仅在设置了过期时间的键中使用 LRU 策略淘汰。

  5. 性能考虑:LRU 策略在实现上需要维护一个有序的数据结构,这可能会对性能产生一定影响,尤其是在高并发场景下。Redis 通过精心设计的数据结构和算法来最小化这种影响。

  6. 与其他策略的比较

    • allkeys-lru:淘汰最久未使用的所有键。
    • volatile-lru:仅淘汰设置了过期时间且最久未使用的键。
    • allkeys-random:随机淘汰任意键。
    • volatile-random:随机淘汰设置了过期时间的键。
  7. 动态调整:Redis 允许在运行时动态调整内存淘汰策略,这使得管理员可以根据应用的具体需求和性能指标来优化内存使用。

LRU 策略是 Redis 中一种有效的内存管理机制,它可以帮助确保 Redis 缓存中保留的是最近被频繁访问的数据,从而提高缓存的效率和响应速度。然而,选择合适的淘汰策略需要根据具体的应用场景和数据访问模式来决定。

相关文章:

  • keepalived交叉编译
  • yarn dev启动项目时遇到的问题
  • 【实战JVM】-基础篇-02-类的声明周期-加载器
  • 春秋CVE-2022-23906
  • ❤职场小心得❤
  • 上交提出TrustGAIN,提出6G网络中可信AIGC新模式!
  • php质量工具系列之paslm
  • 工博科技联手伯尼纳,共谋食品包装外贸行业新市场,助力全球市场拓展!
  • 质量源于设计:QbD培训引领企业产品质量飞跃!
  • 数据库编程
  • 周报 | 24.5.20-24.5.26文章汇总
  • Python函数式编程入门窥探
  • 高弹性架构的微服务设计模式
  • 什么样的跨网文件交换系统适合车企行业?
  • 【Javascript】Promise形象比喻
  • 《微软的软件测试之道》成书始末、出版宣告、补充致谢名单及相关信息
  • 【笔记】你不知道的JS读书笔记——Promise
  • 10个确保微服务与容器安全的最佳实践
  • Git的一些常用操作
  • JavaScript 奇技淫巧
  • JS实现简单的MVC模式开发小游戏
  • Laravel Telescope:优雅的应用调试工具
  • TypeScript迭代器
  • vue-router的history模式发布配置
  • 二维平面内的碰撞检测【一】
  • 老板让我十分钟上手nx-admin
  • 小程序开发中的那些坑
  • “十年磨一剑”--有赞的HBase平台实践和应用之路 ...
  • Spark2.4.0源码分析之WorldCount 默认shuffling并行度为200(九) ...
  • 阿里云ACE认证学习知识点梳理
  • 从如何停掉 Promise 链说起
  • 积累各种好的链接
  • 如何正确理解,内页权重高于首页?
  • ​二进制运算符:(与运算)、|(或运算)、~(取反运算)、^(异或运算)、位移运算符​
  • ###STL(标准模板库)
  • #【QT 5 调试软件后,发布相关:软件生成exe文件 + 文件打包】
  • #鸿蒙生态创新中心#揭幕仪式在深圳湾科技生态园举行
  • #每天一道面试题# 什么是MySQL的回表查询
  • $jQuery 重写Alert样式方法
  • ( 用例图)定义了系统的功能需求,它是从系统的外部看系统功能,并不描述系统内部对功能的具体实现
  • (11)MATLAB PCA+SVM 人脸识别
  • (2024,RWKV-5/6,RNN,矩阵值注意力状态,数据依赖线性插值,LoRA,多语言分词器)Eagle 和 Finch
  • (el-Transfer)操作(不使用 ts):Element-plus 中 Select 组件动态设置 options 值需求的解决过程
  • (LeetCode 49)Anagrams
  • (八)Docker网络跨主机通讯vxlan和vlan
  • (二) 初入MySQL 【数据库管理】
  • (区间dp) (经典例题) 石子合并
  • (十八)devops持续集成开发——使用docker安装部署jenkins流水线服务
  • (十七)Flink 容错机制
  • (数据结构)顺序表的定义
  • (四)库存超卖案例实战——优化redis分布式锁
  • (转)Oracle 9i 数据库设计指引全集(1)
  • (转)关于pipe()的详细解析
  • (转载)在C#用WM_COPYDATA消息来实现两个进程之间传递数据
  • (自适应手机端)行业协会机构网站模板