redis之缓存淘汰策略

2024-09-03 22:20
文章标签 redis 缓存 策略 淘汰

本文主要是介绍redis之缓存淘汰策略,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1.查看redis的最大占用内存

使用redis-cli命令连接redis服务端,输入命令:config get maxmemory
在这里插入图片描述
输出的值为0,0代表redis的最大占用内存等同于服务器的最大内存。

2.设置redis的最大占用内存

编辑redis的配置文件,并重启redis服务
在这里插入图片描述

3.生产环境中redis的最大使用内存配置多少?

正常情况下配置为服务器内存的四分之三。

4.如果redis内存满了会出现什么情况

先使用config set maxmwmery 1命令将redis的最大使用内存设置为1字节
需要注意config set maxmwmery命令重启就失效了,想要永久修改,需要编辑redis的配置文件并重启redis服务。
在这里插入图片描述
然后执行set命令
在这里插入图片描述
当value的值超过redis的最大内存,会抛出OOM异常

5.redis过期键的删除策略

(1)立即删除
对cpu不够友好,用处理器性能换取内存(时间换空间)。
(2)惰性删除
数据达到过期时间,不做处理,等下次访问该数据时,如果未过期,返回数据;发现已过期,删除,返回不存在。
惰性删除没有时效性,可能会造成内存资源的浪费。
惰性删除对内存不够友好,用内存空间换取处理器性能(空间换时间)
redis开启惰性删除配置
在这里插入图片描述
(3)定期删除
定期删除策略每隔一段时间执行一次删除过期键操作并通过限制删除操作执行时长和频率来减少删除操作对CPU时间的影响
举例:redis每隔100ms抽取部分key检查是否过期,过期则删除
定期删除就是基于立即删除和惰性删除的折中的一种删除算法
(4)总结
上述的删除策略都有弊端
当使用定期删除时,过期的key可能从来没有被抽到
当使用惰性删除时,过期的key可能从来没有被访问到
这样大量过期的key堆积在内存中,导致redis内存空间紧张

6.redis共有多少种缓存淘汰策略

redis共有8种缓存淘汰策略(详见redis配置文件)
redis默认的删除策略是noeviction在这里插入图片描述> 在这里插入图片描述

7.lru和lfu算法的区别是什么

LRU means Least Recently Used(最近最少使用,淘汰最长时间没被使用到的)
LFU means Least Frequently Used(最近最不常用,淘汰一定时间段内被访问次数最少的)
举例:
在这里插入图片描述

8.生产中redis的过期策略使用哪一种

简单地说:当不知道自己的业务场景适合哪一种删除策略时,可以使用allkeys-lru 策略。在这里插入图片描述

9.redis配置淘汰策略

编辑redis配置文件,并重启redis服务
在这里插入图片描述

10.redis的淘汰策略什么时候会触发

当Redis设置了最大内存限制(通过 maxmemory 配置项),并且当前使用的内存达到了这个限制,Redis会根据设定的淘汰策略来移除一些键,以便为新的键腾出内存。

这篇关于redis之缓存淘汰策略的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1134214

相关文章

redis群集简单部署过程

《redis群集简单部署过程》文章介绍了Redis,一个高性能的键值存储系统,其支持多种数据结构和命令,它还讨论了Redis的服务器端架构、数据存储和获取、协议和命令、高可用性方案、缓存机制以及监控和... 目录Redis介绍1. 基本概念2. 服务器端3. 存储和获取数据4. 协议和命令5. 高可用性6.

Deepseek使用指南与提问优化策略方式

《Deepseek使用指南与提问优化策略方式》本文介绍了DeepSeek语义搜索引擎的核心功能、集成方法及优化提问策略,通过自然语言处理和机器学习提供精准搜索结果,适用于智能客服、知识库检索等领域... 目录序言1. DeepSeek 概述2. DeepSeek 的集成与使用2.1 DeepSeek API

Redis的数据过期策略和数据淘汰策略

《Redis的数据过期策略和数据淘汰策略》本文主要介绍了Redis的数据过期策略和数据淘汰策略,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录一、数据过期策略1、惰性删除2、定期删除二、数据淘汰策略1、数据淘汰策略概念2、8种数据淘汰策略

SpringBoot中的404错误:原因、影响及解决策略

《SpringBoot中的404错误:原因、影响及解决策略》本文详细介绍了SpringBoot中404错误的出现原因、影响以及处理策略,404错误常见于URL路径错误、控制器配置问题、静态资源配置错误... 目录Spring Boot中的404错误:原因、影响及处理策略404错误的出现原因1. URL路径错

Redis存储的列表分页和检索的实现方法

《Redis存储的列表分页和检索的实现方法》在Redis中,列表(List)是一种有序的数据结构,通常用于存储一系列元素,由于列表是有序的,可以通过索引来访问元素,因此可以很方便地实现分页和检索功能,... 目录一、Redis 列表的基本操作二、分页实现三、检索实现3.1 方法 1:客户端过滤3.2 方法

MySQL 缓存机制与架构解析(最新推荐)

《MySQL缓存机制与架构解析(最新推荐)》本文详细介绍了MySQL的缓存机制和整体架构,包括一级缓存(InnoDBBufferPool)和二级缓存(QueryCache),文章还探讨了SQL... 目录一、mysql缓存机制概述二、MySQL整体架构三、SQL查询执行全流程四、MySQL 8.0为何移除查

Python中操作Redis的常用方法小结

《Python中操作Redis的常用方法小结》这篇文章主要为大家详细介绍了Python中操作Redis的常用方法,文中的示例代码简洁易懂,具有一定的借鉴价值,有需要的小伙伴可以了解一下... 目录安装Redis开启、关闭Redisredis数据结构redis-cli操作安装redis-py数据库连接和释放增

redis防止短信恶意调用的实现

《redis防止短信恶意调用的实现》本文主要介绍了在场景登录或注册接口中使用短信验证码时遇到的恶意调用问题,并通过使用Redis分布式锁来解决,具有一定的参考价值,感兴趣的可以了解一下... 目录1.场景2.排查3.解决方案3.1 Redis锁实现3.2 方法调用1.场景登录或注册接口中,使用短信验证码场

Redis 多规则限流和防重复提交方案实现小结

《Redis多规则限流和防重复提交方案实现小结》本文主要介绍了Redis多规则限流和防重复提交方案实现小结,包括使用String结构和Zset结构来记录用户IP的访问次数,具有一定的参考价值,感兴趣... 目录一:使用 String 结构记录固定时间段内某用户 IP 访问某接口的次数二:使用 Zset 进行

解读Redis秒杀优化方案(阻塞队列+基于Stream流的消息队列)

《解读Redis秒杀优化方案(阻塞队列+基于Stream流的消息队列)》该文章介绍了使用Redis的阻塞队列和Stream流的消息队列来优化秒杀系统的方案,通过将秒杀流程拆分为两条流水线,使用Redi... 目录Redis秒杀优化方案(阻塞队列+Stream流的消息队列)什么是消息队列?消费者组的工作方式每