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。

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

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

相关文章

在线程间共享数据---互斥量

在线程间共享数据—互斥量 std::mutex std::mutex 是C标准库中 <mutex> 头文件中定义的一个类&#xff0c;它是实现多线程同步的基础工具&#xff0c;主要用于保护共享资源&#xff0c;防止多个线程同时访问同一资源造成的数据竞争&#xff08;race condition&#xff0…

Ubuntu安装配置FTP

1、安装服务端 sudo apt-get install vsftpd service vsftpd start service vsftpd stop service vsftpd restart 2、创建目录、用户 mkdir -p /home/xxxx sudo useradd -g ftp -d /home/vsftp -m angler 命令一&#xff1a;这种命令会在登录界面显示用户名 sudo …

vue3大事件项目3

弹框验证 先准备变量: const formModel ref({ cate_name: , cate_alias: }) 还有规则&#xff1a; const rules { cate_name: [ { required: true, message: please input name, trigger: blur }, { pattern: /^\S{1,10}$/, message: must be 1-10, trigger: blur } ], …

Java 基于微信小程序的智能停车场管理小程序

博主介绍&#xff1a;✌程序员徐师兄、7年大厂程序员经历。全网粉丝12w、csdn博客专家、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和毕业项目实战✌ &#x1f345;文末获取源码联系&#x1f345; &#x1f447;&#x1f3fb; 精彩专栏推荐订阅&#x1f447;…

Rust腐蚀服务器常用参数设定详解

Rust腐蚀服务器常用参数设定详解 大家好我是艾西&#xff0c;一个做服务器租用的网络架构师上期我们分享了rust腐蚀服务器的windows系统搭建方式&#xff0c;其中启动服务器bat参数因为涉及的东西比较多所以想通过这篇文章给大家做一下详细的分享。 &#xff08;注本文中xxxx…

浅述.Net中的Hash算法(顺带对称、非对称算法)

【写在前面】 对称加密算法(只有一个私钥&#xff0c;比如DES【不推荐】、AES)&#xff1b; 非对称加密算法&#xff08;公钥与私钥&#xff0c;比如RSA&#xff09;&#xff1b; Hash算法也称为散列函数算法&#xff0c;任意长度的数据都转换为固定长度的字符串&#xff08…

【自然语言处理八-transformer实现翻译任务-一(输入)】

自然语言处理八-transformer实现翻译任务-一&#xff08;输入&#xff09; transformer架构数据处理部分模型的输入数据(图中inputs outputs outputs_probilities对应的label)以处理英中翻译数据集为例的代码 positional encoding 位置嵌入代码 鉴于transfomer的重要性&#xf…

小猫爬山(c++题解)

题目描述 Freda和rainbow饲养了N只小猫&#xff0c;这天&#xff0c;小猫们要去爬山。经历了千辛万苦&#xff0c;小猫们终于爬上了山顶&#xff0c;但是疲倦的它们再也不想徒步走下山了&#xff08;呜咕>_<&#xff09;。 Freda和rainbow只好花钱让它们坐索道下山。索…

1.汉诺塔问题

C力扣 汉诺塔 class Solution { public:void hanota(vector<int>& a, vector<int>& b, vector<int>& c) {dfs(a,b,c,a.size());}void dfs(vector<int>& a, vector<int>& b, vector<int>& c,int n){if(n1){c.push…

阻塞队列和生产消费模型

阻塞队列 阻塞队列的概念 队列相信我们已经不陌生了 之前也学过很多队列 比如: 普通队列 和 优先级队列 两种 这两种队列都是线程不安全的 而我们讲的阻塞队列 刚好可以解决线程安全问题 也是先进先出 并且带有阻塞功能. 阻塞功能是怎么回事呢 就是如果入队的时候阻塞队列为…

rabbitmq安装rabbitmq-delayed-message-exchange插件

下载地址&#xff1a;Community Plugins | RabbitMQ 上传到rabbitmq安装目录的/plugins目录下 我的是/usr/lcoal/rabbitmq/plugins/ 直接安装 [rootk8s-node1 rabbitmq]# rabbitmq-plugins enable rabbitmq_delayed_message_exchange [rootk8s-node1 rabbitmq]# rabbitmq-pl…

pringboot2集成swagger2出现guava的FluentIterable方法不存在

错误信息 Description: An attempt was made to call a method that does not exist. The attempt was made from the following location: springfox.documentation.spring.web.scanners.ApiListingScanner.scan(ApiListingScanner.java:117) The following method did not ex…

《青少年成长管理2024》049 “成长目标:到哪儿了?”2/2

《青少年成长管理2024》049 “成长目标&#xff1a;到哪儿了&#xff1f;”2/2 六、规则和契约七、资源与欲望八、愚蠢与智慧九、奋勇争第一十、时代新节奏 本节摘要&#xff1a;当你来到这个世界&#xff0c;首先认识一下这是一个什么样的世界&#xff0c;你处于一个什么样的环…

c语言例题,求数组中最大值,99乘法口诀表

例题1&#xff1a;求出数组中最大的值 根据题意&#xff0c;我们知道的是需要从一个数组中找到一个最大的元素并且输出。那首先我们先建立一个数组&#xff0c;然后将一些不有序的整型元素放到数组中&#xff0c;然后再建立一个变量来存放数组中的第一个元素&#xff0c;通过一…

Linux学习 - 又双叒叕一个软件安装方法

Linux学习 - 又双叒叕一个软件安装方法 Conda包管理系统 Conda是一种通用包管理系统&#xff0c;旨在构建和管理任何语言的任何类型的软件。通常与Anaconda (集成了更多软件包&#xff0c;https://www.anaconda.com/download/#download)和Miniconda(只包含基本功能软件包, ht…

算法设计与分析实验报告c++实现(八皇后问题、连续邮资问题、卫兵布置问题、圆排列问题)

一、实验目的 1&#xff0e;加深学生对回溯法算法设计方法的基本思想、基本步骤、基本方法的理解与掌握&#xff1b; 2&#xff0e;提高学生利用课堂所学知识解决实际问题的能力&#xff1b; 3&#xff0e;提高学生综合应用所学知识解决实际问题的能力。 二、实验任务 用回溯…

vue简单使用五(组件的使用)

目录 如何定义组件&#xff1a; 组件的命名&#xff1a; 父组件向子组件传值&#xff1a; 子组件向父组件传值&#xff1a; 如何定义组件&#xff1a; 全局组件定义&#xff1a; 局部组件定义&#xff1a; 组件的基本使用&#xff1a; 打印结果&#xff1a; 组件的命名&#xf…

蓝桥杯真题有奖问答

小蓝正在参与—个现场问答的节目。活动中一共有30道题目,每题只有答对和答错两种情况,每答对—题得10分&#xff0c;答错—题分数归零。小蓝可以在任意时刻结束答题并获得目前分数对应的奖项&#xff0c;之后不能再答任何题目。最高奖项需要100分,所以到达100分时小蓝会直接停止…

分类预测 | Matlab实现OOA-BP鱼鹰算法优化BP神经网络数据分类预测

分类预测 | Matlab实现OOA-BP鱼鹰算法优化BP神经网络数据分类预测 目录 分类预测 | Matlab实现OOA-BP鱼鹰算法优化BP神经网络数据分类预测分类效果基本介绍程序设计参考资料 分类效果 基本介绍 1.Matlab实现OOA-BP鱼鹰算法优化BP神经网络多特征分类预测&#xff08;完整源码和数…

MATLAB Simulink仿真搭建及代码生成技术—01自定义新建模型模板

MATLAB Simulink仿真搭建及代码生成技术 目录 01-自定义新建模型模板点击运行&#xff1a;显示效果&#xff1a;查看模型设置&#xff1a; 01-自定义新建模型模板 新建模型代码如下&#xff1a; function new_model(modelname) %建立一个名为SmartAss的新的模型并打开 open_…