新版系统刚发布,前端反馈redis中的值经常被清空,第一反应怀疑谁的代码里面执行了flushall或者flushdb操作

通过redis的monitor追踪一波,

redis-cli -a "xxx" monitor 如果redis没配置密码可以不用加-a参数,实际操作中我加了个 >> /data/log/trace_redis.log,把所有操作写到文件里面,注意时间长了log会很大

跑下来redis确实会被清掉,但没人/程序执行过flush操作,这里停顿5分钟思考下人生

这里幸亏之前转过一个zabbix监控,有监控redis的使用内存,结果发现redis的内存使用情况:

redis会短时间飙到10G,然后马上掉下来,这时候基本可以判定应该跟内存有关,达到某个阈值之后数据被清了。

去翻redis官网有详细记录:https://redis.io/topics/lru-cache

文档查下来确实是因为reids有内存限制,我们这里是10G,并且有超内存之后的清除策略默认是全清。。。

翻开 /etc/redis.conf (实际路径可能不同)

就这里了,maxmemory设置redis最大使用内存,maxmemory-policy决定超过之后怎么清

Redis提供6种数据淘汰策略:

1. volatile-lru:从已设置过期时间的内存数据集中挑选最近最少使用的数据 淘汰;

2. volatile-ttl: 从已设置过期时间的内存数据集中挑选即将过期的数据 淘汰;

3. volatile-random:从已设置过期时间的内存数据集中任意挑选数据 淘汰;

4. allkeys-lru:从内存数据集中挑选最近最少使用的数据 淘汰;

5. allkeys-random:从数据集中任意挑选数据 淘汰;

6. no-enviction(驱逐):禁止驱逐数据。(默认淘汰策略。当redis内存数据达到maxmemory,在该策略下,直接返回OOM错误);

关于maxmemory设置,通过在redis.conf中maxmemory参数设置,或者通过命令CONFIG SET动态修改

关于数据淘汰策略的设置,通过在redis.conf中的maxmemory-policy参数设置,或者通过命令CONFIG SET动态修改

当然这是redis上的策略,实际追踪发现有个程序一直往redis里面push数据导致的上面的现象,问题解决

redis 内存不足 排查_redis莫名数据被清问题排查记录相关推荐

  1. redis 内存不足 排查_Redis 系统学习之 redis 内存模型

    关注:架构师学习路线,每日更新互联网最新技术文章与你不断前行,实战资料,笔试面试 前言 Redis是目前最火爆的内存数据库之一,通过在内存中读写数据,大大提高了读写速度,可以说Redis是实现网站高并 ...

  2. redis 内存不足 排查_Redis内存溢出问题排查

    Redis内存溢出问题排查 最近生产环境服务器上的redis内存波动,导致了一次OOM,查询/var/log/messages后发现原本只会在1~2G大小之间波动的Redis内存竟然达到8G,然后OO ...

  3. redis 内存不足 排查_Redis——内存占用优化

    # 1.优化内存占用 了解redis的内存模型,对优化redis内存占用有很大帮助.下面介绍几种优化场景. - 1)利用jemalloc特性进行优化 上一小节所讲述的90000个键值便是一个例子.由于 ...

  4. 记录一次生产环境中Redis内存增长异常排查全流程!

    作者:z小赵 ★ 一枚用心坚持写原创的"无趣"程序猿,在自身受益的同时也让朋友们在技术上有所提升. 最近 DBA 反馈线上的一个 Redis 资源已经超过了预先设计时的容量,并且已 ...

  5. redis 内存不足 排查_一文深入了解 Redis 内存模型,Redis 的快是有原因的!

    前言 一.Redis内存统计 二.Redis内存划分 1.数据 2.进程本身运行需要的内存 3.缓冲内存 4.内存碎片 三.Redis数据存储的细节 1.概述 2.jemalloc 3.redisOb ...

  6. 写一段代码提高内存占用_记录一次生产环境中Redis内存增长异常排查全流程!...

    点击上方 IT牧场 ,选择 置顶或者星标 技术干货每日送达 最近 DBA 反馈线上的一个 Redis 资源已经超过了预先设计时的容量,并且已经进行了两次扩容,内存增长还在持续中,希望业务方排查一下容量 ...

  7. redis内存占用过高的问题排查

    背景 在往消息系统发送消息,写入redis的时候,出现redis内存飙升的情况,原来redis服务器的内存是16G,占用约8G,后面通过补推业务数据造成了占用到90%的内存.紧急把服务器内存升级到32 ...

  8. redis一般缓存什么样数据_门户数据展示_Redis缓存数据

    学习主题:门户数据展示_Redis缓存数据 一.Redis_3主3从集群环境搭建 谈单你对读写分离和主从同步的理解 读写分离:Master负责写数据的操作,salve负责读数据的操作 主从同步:sal ...

  9. redis php数据插入失败,redis插入数据,恢复数据测试(禁止淘汰策略下恢复大于redis内存限制数据情况)...

    环境准备: redis php的redis扩展 redis version=4.0.8 php version: php version.png php redis extension: php re ...

最新文章

  1. 【Android 热修复】热修复原理 ( 热修复框架简介 | 将 Java 字节码文件打包到 Dex 文件 )
  2. JSP脚本 9大内置对象
  3. 什么是序列化?python pickle模块
  4. 脚本配置文件(通过一个案例解释下什么叫脚本配置文件)
  5. 百度地图iOS API
  6. “ create-react-app”和创建React应用程序的未来
  7. java中如何直接导入println()
  8. 《linux核心应用命令速查》连载一:accton:打开或关闭进程统计
  9. Atitit.Gui控件and面板----web server区----- web服务器监控面板and控制台条目
  10. 【特征提取】基于matlab基音周期估计【含Matlab源码 551期】
  11. ThreadPoolExecutor线程池源码(二) - 核心源码
  12. android麦克风消回音处理,【技术帖】解决麦克风回音重的难题
  13. 密码编码学与网络安全笔记(第7版)
  14. 计算机本地无法连接失败怎么办,本地连接连不上,小编教你电脑本地连接连不上怎么解决...
  15. 医院管理系统软件的全球与中国市场2022-2028年:技术、参与者、趋势、市场规模及占有率研究报告
  16. 【PHP】解决数据库查询出来的中文内容显示为问号“??”
  17. 做智能眼镜是为了更方便地拍摄
  18. catkin_make报错: ROS Base path和Source space不一致问题,
  19. 在eclipse中用java代码测试是否成功连接数据库
  20. 进化计算原理和实现(遗传算法)

热门文章

  1. iOS:quartz2D绘图(给图形绘制阴影)
  2. 设计模式--简单工厂(Factory)模式
  3. Oracle数据库的关闭详解
  4. ajax工具、框架和库
  5. 基于python的快速傅里叶变换FFT(一)
  6. 基于springboot实现高校学生健康档案管理系统
  7. 解决JUnit报错 java.lang.ExceptionNo tests found matching方法
  8. conda (picard)
  9. 产品经理刷题2020.09.20
  10. 基于Grafana+SimpleJson的灵活报表解决方案