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

Redis的过期策略与内存淘汰机制原理及实践

Redis作为高性能的键值存储系统,其对数据过期与内存管理的设计直接影响到系统的性能与资源利用率。本文将以生动的比喻、通俗的语言,深入剖析Redis的过期策略与内存淘汰原理,助您全面理解数据在Redis中的生命周期管理艺术。

一、Redis过期策略:时间沙漏的秘密

想象一下,每个Redis键就像一座装满沙子的时间沙漏。当我们为键设置过期时间时,相当于设定沙漏倒沙的速度。当沙子全部流完,键就会自动消失。这就是Redis的过期策略——基于时间的自动过期清理。

  1. EXPIRE与PEXPIRE:设置键的过期时间,单位分别为秒(EXPIRE)和毫秒(PEXPIRE)。如同设定沙漏倒沙的总时长。

  2. TTL与PTTL:查询键的剩余生存时间,单位分别为秒(TTL)和毫秒(PTTL)。如同观察沙漏剩余沙子的高度,估算剩余时间。

  3. Keyspace Notifications:Redis提供键空间通知功能,当键过期时,可向客户端发送事件通知。如同沙漏倒完时响起的提醒铃声。

  4. 过期键的清理方式

    a.  惰性删除(Lazy Deletion)

    比喻:管理员只在有人请求某个货物时,才查看其标签是否已过期,并适时清理。

    原理:仅在访问键时检查其过期状态,若已过期则立即删除。

    b. 定期删除(Periodic Deletion)

    比喻:仓储系统内置一个智能机器人,定期巡查并清理已过期的货物。

    原理:Redis通过内部定时任务定期扫描并删除已过期键,防止过期键积累。

二、Redis内存淘汰机制:收纳箱整理术

想象你的房间是一个有限大小的收纳箱,里面装满了各种物品(键)。当箱子快满时,你需要决定哪些物品可以暂时收起来,腾出空间放更重要的物品。这就是Redis内存淘汰机制的精髓——在内存不足时,如何选择性地删除部分键,释放内存。

  1. 不淘汰策略(noeviction):默认策略,当内存达到上限且无法分配新空间时,所有写操作(如SET、LPUSH等)都会返回错误。如同收纳箱满载时坚决不再接收任何新物品,保持现状。

  2.  LRU(Least Recently Used):最近最少使用策略,优先删除最近最少使用的键。如同收纳箱里很久没碰过的物品,可能是首先被考虑舍弃的。

  3.  LFU(Least Frequently Used):最不经常使用策略,优先删除访问频率最低的键。如同收纳箱里极少被取出的物品,可能是优先淘汰的对象。

  4.  TTL(Time To Live):优先删除即将过期的键。如同收纳箱里保质期即将到期的物品,优先处理以避免浪费。

  5.  Random(Random eviction):随机删除键。如同收纳箱里随机挑一件物品丢掉,简单粗暴但公平。

三、内存淘汰原理与配置

在Redis配置文件(redis.conf)中,通过maxmemory-policy参数指定内存淘汰策略。当Redis使用的内存达到maxmemory设定值时,触发内存淘汰机制。

四、实战优化与注意事项

  1. 合理设置过期时间:根据业务需求,为键设置合适的过期时间,避免过早或过晚过期导致数据丢失或资源浪费。

  2. 监控内存使用情况:定期检查Redis内存使用情况,通过Keyspace Notifications监控键过期事件,及时发现并处理内存问题。

  3. 选择合适的淘汰策略:根据数据访问模式与业务重要性,选择最适合的淘汰策略。如对访问频率敏感,可选用LFU;对时效性要求高,可选用TTL。

  4. 数据持久化与备份:虽然内存淘汰有助于缓解内存压力,但可能导致重要数据丢失。应结合RDB/AOF持久化与定期备份,确保数据安全。

五、总结

Redis的过期策略犹如精准调控的时间沙漏,自动管理键的生命周期;内存淘汰机制则好比灵活的收纳箱整理术,面对有限内存资源作出明智抉择。理解并合理运用这些策略与机制,不仅能有效管理Redis内存,提高资源利用率,还能确保数据访问的高效与稳定,为业务保驾护航。希望本文的比喻与解读,让您对Redis的过期策略与内存淘汰有了更直观、深入的理解,助您在实践中游刃有余地驾驭Redis。

相关文章:

Redis的过期策略与内存淘汰机制原理及实践

Redis作为高性能的键值存储系统,其对数据过期与内存管理的设计直接影响到系统的性能与资源利用率。本文将以生动的比喻、通俗的语言,深入剖析Redis的过期策略与内存淘汰原理,助您全面理解数据在Redis中的生命周期管理艺术。 一、Redis过期策…...

【24届数字IC秋招总结】提前批面试经验1——小米、百度昆仑芯、长鑫存储

文章目录 前言一、小米-SOC验证工程师1.1 面试问题二、百度昆仑芯-芯片验证工程师2.1 一面面试问题2.2 二面面试问题三、长鑫存储-数字电路前言 提前批面试公司:小米、百度昆仑芯、长鑫存储 一、小米-SOC验证工程师 面试时间:7.23 周末 1.1 面试问题 1、 问研究生项目,自…...

第7章、ReactRedux 实战 - 登录注册验证;

一、登录注册认证系统课程介绍; 1、基本概念; ; 2、代码; 二、搭建前端环境; 1、基本概念; ; 2、代码; 三、搭建后端环境; 1、基本概念; &#xff1…...

16路HDMI+AV流媒体IPTV高清编码器JR-3216HD

产品简介: JR-3216HD 16路高清HDMIAV编码器是专业的高清音视频编码产品,该产品具有支持16路高清HDMI音视频采集功能,16路标清AV视频采集功能,16路3.5MM独立外接音频输入,编码输出双码流H.264格式,音频MP3/…...

vscode 配置文件settings.json和c_cpp_properties.json的作用

前言 在 Visual Studio Code (VSCode) 中,settings.json 和 c_cpp_properties.json 都是配置文件,它们分别用于不同的目的。 settings.json settings.json 文件是 VSCode 的用户或工作区设置文件。它允许你自定义 VSCode 的各种行为和外观。 用户设置…...

【postgresql 基础入门】入门教程成形了,八大章节,涵盖库,表,事务,约束,数据类型,聚集函数,轻松入门

Postgresql 基础入门 ​专栏内容: postgresql内核源码分析手写数据库toadb并发编程 个人主页:我的主页 管理社区:开源数据库 座右铭:天行健,君子以自强不息;地势坤,君子以厚德载物. 序言 Postg…...

【计算机毕业设计】人事管理系统——后附源码

🎉**欢迎来到我的技术世界!**🎉 📘 博主小档案: 一名来自世界500强的资深程序媛,毕业于国内知名985高校。 🔧 技术专长: 在深度学习任务中展现出卓越的能力,包括但不限于…...

OceanBase V4.2 MySQL模式下,如何通过DBLINK实现跨数据源访问

概述 跨数据源访问可通过 DBLINK(以下简称DBLINK)实现,从而使得业务代码能够像访问本地数据库一样轻松访问远端数据库。原先,DBLINK主要服务于Oracle模式,但由于OceanBase 的MySQL模式租户同样存在访问远端数据库的需…...

再谈C语言——理解指针(一)

内存和地址 内存 在讲内存和地址之前,我们想有个⽣活中的案例: 假设有⼀栋宿舍楼,把你放在楼⾥,楼上有100个房间,但是房间没有编号,你的⼀个朋友来找你玩, 如果想找到你,就得挨个房…...

day21-二叉树part08

235. 二叉搜索树的最近公共祖先 相对于 二叉树的最近公共祖先 本题就简单一些了,因为 可以利用二叉搜索树的特性无需全部遍历。特点:当前节点在p,q节点之前则必为最近公共祖先 class Solution {public TreeNode lowestCommonAncestor(TreeNo…...

【WPF应用42】WPF中的 GroupBox 控件详解

在 Windows Presentation Foundation (WPF) 中,控件是构建用户界面 (UI) 的基础。WPF 提供了丰富的控件库,其中包括 GroupBox 控件,它用于将相关的 UI 元素组织到逻辑分组中。在本博客文章中,我们将详细介绍 GroupBox 控件的功能、…...

LeetCode-72. 编辑距离【字符串 动态规划】

LeetCode-72. 编辑距离【字符串 动态规划】 题目描述:解题思路一:动规五部曲解题思路二:动态规划【版本二】解题思路三:0 题目描述: 给你两个单词 word1 和 word2, 请返回将 word1 转换成 word2 所使用的最…...

多张静图合成gif怎么做?一键极速合成gif

图片的格式有很多种,通常分为静态图片和动态图片。而动态图片基本上都是gif格式,想要把其他格式的静图变成gif格式动图的时候要怎么操作呢?通过使用gif动画图片(https://www.gif.cn/)制作网站,上传jpg、png…...

Es中bool 查询中的四个(must must_not should filter)

1.must :相当于and 2.must_not :相当于not 3.should:相当于or 4. filter:过滤 gte 大于 gt大于 lte小于等于 lt小于 使用示例: {“bool”:{“must”:{“match”:{“title”:”how to make millons “}},“must_not”:{“match”:{“tag”:”spam“}},“should”:[{…...

Docker容器嵌入式开发:Docker Ubuntu18.04配置mysql数据库

在 Ubuntu 18.04 操作系统中安装 MySQL 数据库的过程。下面是安装过程的详细描述: 首先,使用以下命令安装 MySQL 服务器: sudo apt install mysql-server系统会提示是否继续安装,按下 Y 键确认。 安装过程中,系统会…...

C++类和对象中上篇

1.类的6个默认成员函数 如果一个类中什么成员都没有,那就简称他为空类。 空类中真的什么都没有吗?并不是,任何类在什么都不写时,编译器会自动生成以下6个默认成员函数。 默认成员函数:用户没有显式实现,…...

基于linux进一步理解核间通讯

芯片架构分为同构和异构: 如下图TC397: 如下图TDA4: 如下图STM32MP157: 非对称多处理结构(AMP): AMP 结构是指每个内核运行自己的 OS 或同一 OS 的独立实例&#...

应用实战|从头开始开发记账本2:基于模板快速开始

上期视频我们创建好了BaaS服务的后端应用。从这期视频开始,我们将从头开发一个互联网记账本应用。本期视频我们介绍一下如何使用模板快速开启我们的应用开发之旅。 应用实战|从头开始开发记账本2:基于模板快速开始 相关代码 本期视频我们介绍…...

学习前端第二十天(条件分支:if 和 ‘?‘;逻辑运算符)

一、条件分支 if (…) 语句会计算圆括号内的表达式,并将计算结果转换为布尔型。 if(...) 语句计算括号里的条件表达式,如果计算结果是 true,就会执行对应的代码块{ }。 if 语句有时会包含一个可选的 “else” 块。如果判断条件不成立&…...

C++11的更新介绍(lamada、包装器)

🪐🪐🪐欢迎来到程序员餐厅💫💫💫 主厨:邪王真眼 主厨的主页:Chef‘s blog 所属专栏:c大冒险 总有光环在陨落,总有新星在闪烁 lambda表达式 C98中的一个…...

Golang 实现一个简单的 RPC 服务

分享一个简单的 rpc 服务框架 一、服务端实现 package mainimport ("log""net""net/rpc" )const HelloServiceName "main.HelloService"type HelloServiceInterface interface {Hello(request string, replay *string) error }func…...

Linux系统(centos,redhat,龙芯,麒麟等)忘记密码,怎么设置新的密码

Linux系统(centos,redhat,龙芯,麒麟等)忘记密码,怎么设置新的密码 今天在操作服务器时,DBA忘记了人大金仓数据库的kingbase密码,他的密码试了好多遍,都不行。最后只能给重置密码了 解决办法&a…...

SpringBoot的启动原理

运行Main方法: 应用程序启动始于Main方法的执行。在Main方法中,创建了一个SpringApplication实例,用于引导应用程序的启动。同时,SpringApplication会根据spring.factories文件加载并注册监听器、ApplicationContextInitializer等…...

git查看单独某一个文件的历史修改记录

git查看单独某一个文件的历史修改记录 git log -p 文件具体路径 注意,Windows下默认文件路径分隔符是 \,在git bash 里面需要改成 /。 git基于change代码修改与提交_git change-CSDN博客文章浏览阅读361次。git cherry-pick:复制多个提交comm…...

一键开启Scrum回顾会议的精彩时刻

其实回顾会议作为一个检视、反馈、改进环节,不仅在传统的瀑布管理模式中,还是在Scrum一类的敏捷管理流程中,都是非常重要的活动。一些团队认为它无法产生直接的价值,所以有意忽略了这个会议;一些团队在越来越多的回顾中…...

Python计算多个表格中多列数据的平均值与标准差并导出为新的Excel文件

本文介绍基于Python语言,对一个或多个表格文件中多列数据分别计算平均值与标准差,随后将多列数据对应的这2个数据结果导出为新的表格文件的方法。 首先,来看一下本文的需求。现有2个.csv格式的表格文件,其每1列表示1个变量&#x…...

nginx支持的多种负载均衡策略

目录 1.轮询(默认) 2. ip_hash 3. 加权轮询(weight) 4. fair(第三方) 5. 最少连接(least_conn) 1.轮询(默认) 将请求依次分配给每个服务器,确…...

FNP preptool has not been run on this executable

pycharm导入arcgis pro的python运行程序后提示 我也看了很多解决方法,也重新安装过一遍,终于看到一个说法是你的arcgis pro是学习版所以才会有这个提示,不会影响输入 测试代码 import arcpy print(arcpy.GetInstallInfo()[Version])输出结果…...

算法-反转单向链表

需求 思路 链表必有节点&#xff0c;节点两要素&#xff1a;当前元素值&#xff0c;下一个节点地址 import java.util.Scanner;// 定义一个单向链表 public class MyLinkedList<E> {int size 0;// 顶一个私有的内部类&#xff0c;表示链表的节点public class Node {E da…...

Ps 滤镜:方框模糊

Ps菜单&#xff1a;滤镜/模糊/方框模糊 Filter/Blur/Box Blur 方框模糊 Box Blur滤镜通过计算图像中每个像素及其周围像素的平均颜色值来实现模糊效果。适合于需要突出主题、减少背景&#xff08;尤其是颜色变化&#xff09;干扰的场景。 “方框模糊”滤镜按照设定的半径值&…...

福州建设厅官方网站/国产系统2345

CSMA/CD&#xff08;CarrierSenseMultipleAccesswithCollisionDetection&#xff09;即带冲突检测的载波监听多路访问技术(载波监听多点接入/碰撞检测)。在传统的共享以太网中&#xff0c;所有的节点共享传输介质。如何保证传输介质有序、高效地为许多节点提供传输服务&#xf…...

云南旅游网站建设公司/搜狗收录查询

window对象常见事件 调整窗口大小 window.onresize window.onresize为调整窗口大小触发事件&#xff0c;通俗来讲就是当调整浏览器可视区的大小的时候触发onresize事件。 使用方法如下 <body><script>window.addEventListener(resize, function () {console.lo…...

网站建设优化现状图表/小说推广平台有哪些

题意简概&#xff1a; 输入n个元素组成的序列S&#xff0c;你需要找一个乘积最大的连续子序列。如果这个最大的乘积不是正数&#xff0c;应输出0&#xff0c;表示无解。1<n<18&#xff0c;-10<Si<10。 Sample Input32 4 -352 5 -1 2 -1Sample OutputCase #1: The m…...

重庆建设工程交易中心官网/搜索优化推广公司

功能已经做完后, 发现有JS跨站访问的问题. 自己写了段JS请求转发器来解决这个问题. 情况是这样的: 请求Web服务器返回页面, 根据页面选择的条件绑定JS脚本在按钮上, 点击按钮之后, 需要发请求给Jenkins(跟Web服务器不在一起), 并解析Jenkins的返回结果, 显示在Web页面上. 典型…...

wordpress博客管理/个人可以做推广的平台有哪些

与数组的区别&#xff1a;   数组的长度是固定的&#xff0c;集合的长度是可变的。数组用来存放基本类型的数据&#xff0c;集合用来存放对象的引用。 1、集合类接口的常用方法 COllection接口是层次结构中的根接口&#xff0c;该接口提供了添加和删除元素、管理数据的方法。…...

seo快速提高网站转化率/凡科官网免费制作小程序

2019独角兽企业重金招聘Python工程师标准>>> svn代码版本管理1.0开发&#xff0c;做dev1.0的branch此时的目录结构svn://proj/ trunk/ (不负担开发任务) branches/ dev_1.0 (copy from trunk) tags/…...