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

Redis的缓存淘汰策略

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

        打开redis配置文件, 设置maxmemory参数,maxmemory 是bytes字节类型, 注意转换

2. Redis默认内存多少可以用

        

注意: 在64bit系统下, maxmemory 设置为 0 表示不限制Redis内存使用

3. 一般生产上如何配置

        一般推荐Redis 设置内存为最大物理内存的四分之三

4. 如何修改redis 内存配置

        4.1 配置文件修改

        

        4.2 通过命令修改

        

5. 什么命令查看redis内存使用情况

        info memory

        config get maxmemory

6.如果redis 内存满了超过设置的最大值会怎么样

        

没有过期时间的 key 将redis的内存用满,为了避免这种情况,则引出redis的内存淘汰策略

7.先说说Redis 的三种key过期删除策略

        7.1 立即删除

                key 过期立即删除,对cpu不够友好, 用处理器性能换取存储空间 (即空间换时间)

        7.2 惰性删除

                开启憜性淘汰,lazyfree-lazy-eviction=yes

                访问key时候判断key是否过期,对内存不够友好,用存储空间换取性能 (即时间换空间)

        7.3 定期删除

                定期删除策略每隔一段时间执行一次删除过期键操作并通过限制删除操作执行时长和频率来减少删除操作对CPU时间的影响。

                周期性轮询redis库中的时效性数据,采用随机抽取的策略,利用过期数据占比的方式控制删除频度 

                特点1:CPU性能占用设置有峰值,检测频度可自定义设置 
                特点2:内存压力不是很大,长期占用内存的冷数据会被持续清理 
                总结:周期性抽查存储空间 (随机抽查,重点抽查) 
redis默认每隔100ms检查是否有过期的key,有过期key则删除。 注意:redis不是每隔100ms将所有的key检查一次而是随机抽取进行检查( 如果每隔100ms,全部key进行检查,redis直接进去ICU)。因此,如果只采用定期删除策略,会导致很多key到时间没有删除。
定期删除策略的难点是确定删除操作执行的时长和频率:如果删除操作执行得太频繁或者执行的时间太长,定期删除策略就会退化成立即删除策略,以至于将CPU时间过多地消耗在删除过期键上面。如果删除操作执行得太少,或者执行的时间太短,定期删除策略又会和惰性删除束略一样,出现浪费内存的情况。因此,如果采用定期删除策略的话,服务器必须根据情况,合理地设置删除操作的执行时长和执行频率。

         如果定期删除是, 从来没有被抽到, 惰性删除也从来没有被点中使用过,也依然会有大量的过期key堆积在内存中,也会导致redis内存空间紧张或者很快耗尽

8. redis 7 配置文件的内存淘汰策略

        


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

        

10. 细说8中淘汰策略

        

11. 如何使用

不过在日常使用中避免bigkey 以及开启憜性淘汰,lazyfree-lazy-eviction=yes

http://www.lryc.cn/news/430058.html

相关文章:

  • 【C++】深度解析:用 C++ 模拟实现 priority_queue类,探索其底层实现细节(仿函数、容器适配器)
  • 1个人躲,5个人抓!《极限竞速:地平线5》全新游戏模式“捉迷藏”即将推出
  • ARCGIS XY坐标excel转要素面
  • MyBatis源码系列3(解析配置文件,创建SqlSessionFactory对象)
  • 企业级web应用服务器tomcat
  • 深入浅出,探讨IM(即时通讯-聊天工具)技术架构及用户界面设计
  • 小米、友邦带领恒指大反攻!
  • 中国植物性状数据库
  • [数据集][目标检测]街灯路灯检测数据集VOC+YOLO格式1893张1类别
  • C++位运算
  • Day97:云上攻防-云原生篇KubernetesK8s安全APIKubelet未授权访问容器执行
  • 招聘|头部云厂商招 PG 核心骨干 DBA【上海】
  • 继承(下)【C++】
  • AI模拟器
  • 【C++二分查找 前缀和】1658. 将 x 减到 0 的最小操作数
  • 验证实战知识点--(2)
  • 【图文并茂】ant design pro 如何优雅地把删除和批量删除功能合并到一起,并抽出来成为组件
  • 监控篇之利用dcgm-exporter监控GPU指标并集成grafana大盘
  • 获取当前路由器的外网IP(WAN IP)
  • QT Creator UI中文输入跳出英文
  • Java基础核心知识学习笔记
  • Leetcode 237.19.83.82 删除链表重复结点 C++实现
  • Spring OAuth2.0资源服务源码解析
  • JavaScript 原型与原型链
  • Spring Boot实现简单的Oracle数据库操作
  • 微软发布 Phi-3.5 系列模型,涵盖端侧、多模态、MOE;字节 Seed-ASR:自动识别多语言丨 RTE 开发者日报
  • 笔记:Echarts柱状图 实现滚轮条 数据太多
  • 嵌入式学习day17(数据结构)
  • 网站怎么做敏感词过滤,敏感词过滤的思路和实践
  • 【峟思】如何使用投入式水位计才能确保测量准确性