Redis的过期策略与内存淘汰机制详解

news2024/12/25 1:56:19

文章目录

    • Redis的过期策略
      • 1. 定时删除
      • 2. 惰性删除
      • 3. 定期删除
    • Redis的内存淘汰机制
      • 1. noeviction
      • 2. volatile-random
      • 3. volatile-ttl
      • 4. volatile-lru
      • 5. volatile-lfu
      • 6. allkeys-random
      • 7. allkeys-lru
      • 8. allkeys-lfu
    • LRU与LFU算法
    • 总结

Redis作为一种高性能的键值对存储系统,广泛应用于缓存、消息中间件等多种场景。然而,Redis的内存是有限的,当内存达到上限时,就需要通过过期策略和内存淘汰机制来管理数据,确保系统的稳定运行。本文将详细介绍Redis的过期策略及内存淘汰机制。

Redis的过期策略

Redis提供了三种主要的过期策略来处理数据的过期问题:定时删除、惰性删除和定期删除。每种策略都有其优缺点,Redis在实际使用中通常会将定期删除和惰性删除结合使用,以达到最优的性能和资源利用。

1. 定时删除

定时删除策略为每个设置了过期时间的key创建一个定时器,当key过期时立即删除。这种策略的优点是可以立即释放内存,对内存友好;但其缺点也非常明显,会占用大量的CPU资源去处理过期数据,从而影响缓存的响应时间和吞吐量。因此,Redis默认不采用这种策略。

2. 惰性删除

惰性删除策略不主动删除key,而是在每次读写操作之前检查key是否过期,如果过期则删除。这种策略的优点是CPU处理次数少,只有访问到过期key时才会进行删除操作;但其缺点是如果大量key过期而长时间未被访问,则会占用大量内存。

3. 定期删除

定期删除策略是定时删除和惰性删除的一个折中方案。Redis默认会每秒进行十次过期扫描(100ms一次),但并不是遍历所有设置了过期时间的key,而是随机选择一部分key进行检查,如果过期则删除。这种策略既节省了CPU资源,又避免了内存浪费,是Redis推荐的过期处理策略。

Redis的内存淘汰机制

当Redis的内存使用达到maxmemory限制时,就需要通过内存淘汰机制来释放内存空间。Redis 4.0之后,提供了8种内存淘汰策略供用户选择。

1. noeviction

默认策略,不进行数据淘汰,当内存达到maxmemory时,拒绝所有写入操作并返回错误信息。这种策略适用于不希望丢失任何数据的场景,但会限制Redis的写入能力。

2. volatile-random

在设置了过期时间的键值对中,随机移除某个键值对。适用于对过期数据没有特殊要求的场景。

3. volatile-ttl

在设置了过期时间的键值对中,移除即将过期的键值对(ttl最小的)。这种策略可以优先释放即将过期的数据,但可能不是最优的淘汰选择。

4. volatile-lru

在设置了过期时间的键值对中,移除最近最少使用的键值对。这是最常见的淘汰策略之一,适用于缓存场景。

5. volatile-lfu

在设置了过期时间的键值对中,移除最近最不频繁使用的键值对。适用于需要频繁访问热数据的场景。

6. allkeys-random

在所有键值对中,随机移除某个键值对。这种策略较为简单,但可能导致重要数据被误删除。

7. allkeys-lru

在所有键值对中,移除最近最少使用的键值对。与volatile-lru类似,但适用于所有数据,不仅仅是设置了过期时间的数据。

8. allkeys-lfu

在所有键值对中,移除最近最不频繁使用的键值对。与volatile-lfu类似,但适用于所有数据。

LRU与LFU算法

LRU(Least Recently Used)和LFU(Least Frequently Used)是Redis内存淘汰机制中最常用的两种算法。

  • LRU算法:通过维护一个双向链表,记录每个数据项最近一次被访问的时间。当内存达到上限时,优先淘汰最长时间未被访问的数据项。
  • LFU算法:通过记录每个数据项被访问的次数,当内存达到上限时,优先淘汰最近一段时间内被访问次数最少的数据项。

Redis在实现这两种算法时,为了优化性能,采用了近似的算法,而不是严格的LRU或LFU算法。

总结

Redis的过期策略和内存淘汰机制是确保系统稳定运行和高效利用内存的重要手段。通过合理选择过期策略和内存淘汰策略,可以在不同场景下达到最优的性能和资源利用效果。在实际应用中,建议根据具体业务需求和系统环境来选择合适的策略,以最大化Redis的性能和稳定性。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1996168.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

C语言 之 理解指针(9)与指针相关的理解题

文章目录 代码1代码2代码3代码4代码5代码6代码7 本篇内容接上一篇&#xff0c;对指针进行一个更深入的理解 建议没看过 上一篇的可以看看上一篇&#xff0c;当然不看也可以。 建议先自行完成再看答案哟 代码1 #include <stdio.h> int main() {int a[5] { 1, 2, 3, 4, …

B站千亿级点赞系统服务架构设计

B站千亿级点赞系统服务架构设计 原文链接&#xff1a;https://www.bilibili.com/read/cv21576373/ 原文作者&#xff1a;哔哩哔哩技术团队-芦文超 点赞的功能太过于简单不再赘述&#xff0c;大家可以点击原文链接简单看下便可知晓。 本讲结合B站知名UP主陆总监的一期视频(h…

【vue3|第21期】Vue3中Vue Router的push和replace方法详解

日期&#xff1a;2024年8月9日 作者&#xff1a;Commas 签名&#xff1a;(ง •_•)ง 积跬步以致千里,积小流以成江海…… 注释&#xff1a;如果您觉得有所帮助&#xff0c;帮忙点个赞&#xff0c;也可以关注我&#xff0c;我们一起成长&#xff1b;如果有不对的地方&#xff…

Android系统Android.bp文件详解

文章目录 1. 基本语法结构2. 常见模块类型3. 模块属性常见属性包括&#xff1a; 4. 具体示例5. 高级功能5.1. 条件编译5.2. 变量定义与使用5.3. 模块继承 6. 总结 Android.bp 是 Android 构建系统&#xff08;Android Build System&#xff09;中的配置文件&#xff0c;用于描述…

C语言典型例题31

《C程序设计教程&#xff08;第四版&#xff09;——谭浩强》 习题2.8 请编写程序将China译为密码&#xff0c;密码的规律是&#xff1a;用原来字母后面的第4个字母代替原来的字母。 例如:C后面的4个字母是G&#xff0c;h后面第4个字母为l 代码&#xff1a; //《C程序设计教程…

TinyLLaVA: A Framework of Small-scale Large Multimodal Models

发表时间&#xff1a;22 Feb 2024 论文链接&#xff1a;https://arxiv.org/pdf/2402.14289 作者单位&#xff1a;SKLCCSE, Institute of Artificial Intelligence, Beihang University, Beijing, China Motivation&#xff1a;当前的大语言模型的参数量太大了&#xff0c;作…

flask学习-day1

介绍 django是大而全&#xff0c;flask是轻量级的框架 django提供非常多组件&#xff1a;orm/session/cookie/admin/form/modelform/路由/视图/模板/中间件/分页/auth/contentype/缓存/信号/多数据库连接 flask本身没有太多的功能&#xff1a;路由/试视图/模板/session/中间件…

【C++ 面试 - 基础题】每日 3 题(八)

✍个人博客&#xff1a;Pandaconda-CSDN博客 &#x1f4e3;专栏地址&#xff1a;http://t.csdnimg.cn/fYaBd &#x1f4da;专栏简介&#xff1a;在这个专栏中&#xff0c;我将会分享 C 面试中常见的面试题给大家~ ❤️如果有收获的话&#xff0c;欢迎点赞&#x1f44d;收藏&…

24/8/9算法笔记 决策树VS线性回归

from sklearn.tree import DecisionTreeRegressorfrom sklearn.linear_model import LinearRegressionfrom sklearn import datasetsfrom sklearn.model_selection import train_test_split import numpy as np X,y datasets.load_diabetes(return_X_yTrue)#糖尿病数据 X_tra…

03、MySQL-DQL(数据查询语言)

目录 1、编写顺序 2、基本查询 3、条件查询 4、聚合函数 5、分组查询 6、排序查询 7、分页查询 8、执行顺序 1、编写顺序 SELECT 字段列表 FROM 表名列表 WHERE 条件列表 GROUP BY 分组字段列表 HAVING 分组后条件列表 ORDER BY 排序字段列表 LIMIT 分页参数2、基本查…

Cesium初探-相机

在 Cesium 中&#xff0c;相机&#xff08;Camera&#xff09;是一个非常重要的概念&#xff0c;它代表了用户观察 3D 场景的视角。相机不仅决定了用户看到的内容&#xff0c;还定义了观察的角度、距离和方向。理解 Cesium 中的相机是如何工作的对于创建有效的 3D 地图和地球应…

关于Redis的面试题(一)

一、为什么要使用Redis 内存数据库&#xff0c;速度很快工作单线程worker&#xff0c;串行化&#xff0c;原子操作&#xff0c;IO线程是多线程的。避免上下文切换使用 IO模型&#xff0c;天生支撑高并发kv模型&#xff0c;v具有类型结构具有本地方法&#xff0c;计算数据移动二…

政府经济学(练习题)

政府经济学&#xff08;练习题&#xff09; 一、单项选择题 政府经济活动的主体是&#xff08; &#xff09;。 A.各级政府 B.各级人大 C.各级政协 D.各级党委政府经济的依据主要是&#xff08; &#xff09;。 A.私人财产所有权 B.社会公共权力 C.道德劝说 D.法律制度1776年亚…

通过指令深入了解Linux 3

&#x1f308;个人主页&#xff1a;Yui_ &#x1f308;C语言笔记专栏&#xff1a;C语言笔记 &#x1f308;数据结构专栏&#xff1a;数据结构 文章目录 1.Linux下的基本指令1.1 more指令&#xff08;有更好的平替&#xff09;1.2 less指令1.3 head指令1.4 tail指令1.5 date指令…

二、Matlab图像处理基础

文章目录 一、Matlab图像处理工具箱二、图像文件的读取2.1 文件信息的读取2.2 图像文件的读取2.3 图像文件的保存2.4 图像文件的显示2.5 像素信息的显示 本章知识点总结 一、Matlab图像处理工具箱 在帮助文档可以搜索到图像处理工具箱的介绍 二、图像文件的读取 2.1 文件信息…

论文笔记:OneBit: Towards Extremely Low-bit Large Language Models

202402 arxiv 1 背景 模型量化主要通过把模型的线性层【nn.Linear】&#xff08;Embedding 层和 Lm_head 层除外&#xff09;转化为低精度表示实现空间压缩 此前工作的基础是利用 Round-To-Nearest&#xff08;RTN&#xff09;方法把高精度浮点数近似映射到附近的整数网格然而…

Sqlserver 创建只读权限用户

Sqlserver 创建只读权限用户 1、右键登录名->新建登录名 2、在常规选项卡中配置登录名、密码、数据库 3、服务器角色选项卡中配置只读角色 4、配置用户映射 5、安全对象选项卡和状态选项卡默认即可

Hadoop集群安装配置,spark集群安装配置

前提&#xff1a;准备3台linux服务器&#xff0c;并保证其网络可进行相互通信 假设三台机器IP分别为&#xff1a; 192.168.88.101 192.168.88.102 192.168.88.103一.配置三台服务器之间SSH免密登录,关闭防火墙&#xff0c;时间同步 三台服务器均执行以下1,2,3,4,5,6,8命令 1…

C++ primer plus 第17 章 输入、输出和文件:文件输入和输出03:文件模式:二进制文件

系列文章目录 17.4.5 文件模式 程序清单17.18 append.cpp 程序清单17.19 binary.cpp 文章目录 系列文章目录17.4.5 文件模式程序清单17.18 append.cpp程序清单17.19 binary.cpp17.4.5 文件模式1.追加文件来看一个在文件尾追加数据的程序。程序清单17.18 append.cpp2.二进制文…

05_ Electron 自定义菜单、主进程与渲染进程通信

Electron 自定义菜单、主进程与渲染进程通信 一、定义顶部菜单二、Electron 自定义右键菜单1、使用 electron/remote 模块实现 三、 Electron 主进程和渲染进程通信场景1&#xff1a;渲染进程给主进程发送异步消息场景2&#xff1a;渲染进程给主进程发送异步消息&#xff0c;主…