news 2026/4/23 18:47:26

Redis内存使用率在95%以上,请问是什么原因?如何解决?

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Redis内存使用率在95%以上,请问是什么原因?如何解决?

内存使用率在生产环境一般会有三种场景:

  1. 一直都很高 比如95%以上
  2. 突然飙高,一般和瞬时流量有关,内存使用率达到100%
  3. 只是某个节点飙高 ,内存使用率达到100%

场景不一样,问题的原因也可能不一样,解决方案也会不一样。具体的问题原因以及解决方案如下。

一、内存使用率长期处于高水位的解决办法

  1. 盘点下key的使用情况,清理掉无用的key;
  2. 看下key是否设置了合适的TTL策略,避免一直存在redis中;
  3. 检查是否有大key,大key很多的话,就会占用很多内存;
  4. 根据业务需求,设置合理的数据逐出策略,主要是调整maxmemory-policy参数的值;
  5. 根据业务需求,设置合理的过期Key主动删除的执行频率(即调整hz参数的值);
  6. 经过上述步骤优化后,内存使用率依旧较高,可以考虑从硬件配置上入手加大内存。

二、内存使用率突然上升的解决办法

1. 问题原因

内存使用率突然升高一般和瞬时并发流量有关,具体表现为:

  1. 短时间内大量写入新数据;
  2. 短时间内大量创建新连接;
  3. 突发访问产生大量流量超过网络带宽,导致输入缓冲区和输出缓冲区积压;
  4. 客户端处理速度跟不上Redis的处理速度,导致输出缓冲区积压。

2. 具体解决方案

  1. Redis性能监控的入流量与写QPS一致的话,也就是说流量可以承接,可能是写数据太大导致,这个需要升级下redis内存配置,也可以清理下无效的key,腾出更多的空间;
  2. 如果连接数突增的话,首先排除链接是否泄漏,正常关闭;或者设置连接超时时间(timeout 参数),自动关闭空闲连接;
  3. 执行MEMORY STATS命令,看下clients.normal占用的内存是否过多。如果是的话,排查业务流量突发原因或者提升带宽;
  4. 执行MEMORY DOCTOR命令,查看big_client_buf的值。当big_client_buf=1时,代表至少有一个客户端的输出缓冲区占用内存较大。执行CLIENT LIST命令,查看哪个客户端的输出缓冲区内存占用量(omem)较大。排查该客户端应用是否存在性能问题。

三、单个节点内存飙高

这种情况一般都是hash到这个分片大key或者热点key 有关系,一般解决办法是:

  1. 拆分key,分散单个节点流量,使数据更加均匀地分布在不同的数据分片节点上;
  2. 增加redis实例的内存,进行扩容。
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/23 13:53:38

SARSIM 数据集的格式

1. 数据集结构 该数据集由 图片数据 和 元数据标签 两部分组成,按背景杂波类型(Surface)分为三个子集: Grass (草地): SURF_grass.csv (7056 样本) Medium (中等粗糙度): SURF_medium.csv (7056 样本) Roads (道路): SURF_road…

作者头像 李华
网站建设 2026/4/23 11:36:56

在Linux中,有多种命令可以向指定文件添加文本

在Linux中,有多种命令可以向指定文件添加文本,以下是常用的几种方式:1. 使用重定向操作符追加内容到文件末尾# 单行文本 echo "文本内容" >> 文件名# 多行文本(使用 Here Document) cat >> 文件…

作者头像 李华
网站建设 2026/4/23 12:59:36

【[CISCN 2022 初赛]ez_usb】

usb流量分析类型思路:首先找到HID DATA或者Leftover Capture Data,因为键盘和鼠标产生的流量就在这里面键盘数据包长度为8个字节第一个字节:代表特殊按键 第二个字节:是保留位 第三个字节~第八个字节:第三个字节是普通…

作者头像 李华