Redis简单运维学习


周一早上刚上班,突然大量用户反馈进入网页很慢,登录服务器一看,Redis调用时间严重超时,这样高速的缓存反而变成了短板,由于数据一直没有返回,导致了请求响应变慢。

网页监控

通过阿里的 Grafana 监控,服务器的 CPU 负载、内存、网络输入输出都挺正常的,所以肯定是 Redis 出现了问题。

我们应用使用的是单节点的 32M 16GB 的阿里云 Redis,登录网页监控看性能监控,发现 CPU 使用情况飙升到100%!!!

QPS 虽然从 1000 多升到 6000,但是远远低于极限值,连接数量从 0 升到 3000,也是远远低于极限值(可能用户刚上班,开始有请求,然后响应延迟,导致命令队列数量过多,打开很多连接)。

临时方案:先租用一台新的 Redis 服务器,更换应用服务器的 Redis 配置,重启应用,避免影响更多用户。

然后我们继续跟踪 Redis 的具体情况。


服务器命令监控

登录 Redis-cli,通过 info 命令查看服务器状态和命令统计,祥哥总结了两点异常点:

  • 查询 redis 慢指令 slowlog,排行前十的指令均为'keys *',并且耗时严重,在当前业务流量下执行'keys *',一定会阻塞业务,导致查询慢,cpu 高的。值得注意的是应用层面没有开放 'keys *' 接口,不排查有后台人为或后台程序触发该指令。

  • 查看 redis 指令执行情况,排除 'exec','flushall' 等指令,业务使用指令中,耗时严重的有 setnx 有7.5千万次调用平均耗时 6s,setex 有8.4千万次调用平均耗时7.33s,del 有2.6亿次调用平均耗时69s,hmset 有1亿次调用平均耗时 64s,hmget 有6.8千万次调用平均耗时 9s,hgetall 有14亿次调用平均耗时 205s,keys 有2千万次调用平均耗时 3740s。 通常而言,这些指令耗时与 value 大小呈正比,所以可以排查这些指令相关的数据近期有没有较大增长。或者近期有没有业务改造,会频繁使用上述指令,也会造成 cpu 高。

(当时忘了截图,下图只是展示命令和参数含义)

通过 info commandstats 可以查看 Redis 命令统计信息,其中命令格式是

cmdstat_XXX: calls=XXX,usec=XXX,usec_per_call=XXX
调用次数、耗费CPU时间、每个命令平均耗费CPU(单位为微秒)
复制代码

通过 slowlog 命令查看慢命令(默认超过 10ms 就会被记录到日志,只会记录其命令执行的时间,不包含 IO 往返操作,也不记录单由网络延迟引起的响应慢)

(当时也忘了截图,所以就介绍一下 slowlog 怎么看)

xxxxx> slowlog get 103) 1) (integer) 411           2) (integer) 1545386469     3) (integer) 232663          4) 1) "keys"              2) "mecury:*"
复制代码

图中各字段表示的是:

  • 1=日志的唯一标识符
  • 2=命令的执行时间点,以UNIX时间戳表示
  • 3=查询命令执行时间,以微妙为单位,?中的是230ms
  • 4=执行的命令,以数组的形式排列。完整的命令是 keys mucury:*

所以通过这些参数,基本可以确定,是突然有大量的keys *命令导致CPU负载升高,导致响应延迟,问题我们应用中没有开放keys *命令Σ(o゚д゚oノ)

*最后将这些统计结果和慢命令发到研发群,发现是别的应用配置配成了我们的Redis,然后他们有个业务场景是爬数据,突然涌入大量的调用,不断的keys ,导致我们的Redis不堪重负,于是将配置修改正确,不再调用我们的Redis。


总结

  • Redis 抖动可以先看网页监控(阿里云做的真好!)
  • 通过命令查看 Redis 指令状态和慢命令的情况
  • 考虑优化 Redis 在代码中的使用情况
  • 如果流量继续上升,需要考虑一下升级了=-=

参考文章

  1. Redis性能问题排查解决手册(七)
  2. redis info command

Redis高负载排查记录相关推荐

  1. Redis 高负载排查记录

    来源:https://www.sevenyuan.cn/ 周一早上刚上班,突然大量用户反馈进入网页很慢,登录服务器一看,Redis调用时间严重超时,这样高速的缓存反而变成了短板,由于数据一直没有返回, ...

  2. 记一次线上Redis高负载排查经历

    作者:JingQ https://www.sevenyuan.cn/ 周一早上刚上班,突然大量用户反馈进入网页很慢,登录服务器一看,Redis调用时间严重超时,这样高速的缓存反而变成了短板,由于数据一 ...

  3. mysql故障排查思路_Mysql高负载排查思路

    发现问题 top命令 查看服务器负载,发现 mysql竟然百分之两百的cpu,引起Mysql 负载这么高的原因,估计是索引问题和某些变态SQL语句. 排查思路 1. 确定高负载的类型,top命令看负载 ...

  4. 高cpu_再一次生产 CPU 高负载排查实践

    (给ImportNew加星标,提高Java技能) 作者:crossoverJie segmentfault.com/a/1190000019507028 前言 前几日早上打开邮箱收到一封监控报警邮件: ...

  5. java获取cpu使用率_再一次生产 CPU 高负载排查实践

    前言 前几日早上打开邮箱收到一封监控报警邮件:某某 ip 服务器 CPU 负载较高,请研发尽快排查解决,发送时间正好是凌晨. 其实早在去年我也处理过类似的问题,并记录下来:<一次生产 CPU 1 ...

  6. qt获取cpu使用率_又一次生产 CPU 高负载排查实践

    以下文章来源于crossoverJie ,作者crossoverJie 前言 前几日早上打开邮箱收到一封监控报警邮件:某某 ip 服务器 CPU 负载较高,请研发尽快排查解决,发送时间正好是凌晨. 其 ...

  7. 又一次生产 CPU 高负载排查实践

    本文经授权转载自微信公众号:crossoverJie 前言 前几日早上打开邮箱收到一封监控报警邮件:某某 ip 服务器 CPU 负载较高,请研发尽快排查解决,发送时间正好是凌晨. 其实早在去年我也处理 ...

  8. Redis 高负载下的中断优化

    背景 2017年年初以来,随着Redis产品的用户量越来越大,接入服务越来越多,再加上美团点评Memcache和Redis两套缓存融合,Redis服务端的总体请求量从年初最开始日访问量百亿次级别上涨到 ...

  9. CPU高负载排查小技巧(2分钟速读版),细心的优化可能为公司节省一个亿!

    女主宣言 服务优化是一个细心.漫长的过程,一个很小的优化不仅可以为用户带来更稳定更快速的互联网体验,也许还会为公司降低百万以上的成本.熟练掌握服务端排错技巧,已经是"匠心工程师"的 ...

最新文章

  1. 谷歌大脑发布神经网络的「核磁共振」,并公开相关代码
  2. Photoshop 融合属性 Unity Shader
  3. openStack 租户控制台修改虚拟机账户密码
  4. (原创)浅谈BUG资产,用例资产的作用
  5. java thread 线程销毁_手把手带你了解Java线程的实现方式及生命周期原理
  6. 集合竞价如何买入_世界上最稳健的抓涨停方法“10分钟集合竞价”选股诀窍,买入直接稳赚10个点,赚到笑...
  7. 数据结构之队列java版
  8. linux vim 编译python,Ubuntu下编译Vim8(+python)无数次编译失败
  9. C语言如何分离一个数的高低位,如何将2个字节变成一个字节
  10. 计算机xp系统ie8,教你能够完全windows XP下IE8的方法
  11. matlab积分器重置功能,MATLABSIMULINK积分器相关操作.docx
  12. yarn的安装和使用
  13. python中3 and not 5_Python控制結構3.布林邏輯:and,or,not
  14. 浅谈(零火)智能开关和(单火)智能开关的工作原理和优势区别
  15. 如何冻结excel表格前二列
  16. 手把手带你 Unity 入门之从零创建一个时钟(GameObjects 与 Scripts)
  17. 大英百科挂了,维基百科赢了
  18. 格子玻尔兹曼法学习记录(附MATLAB画图源程序)
  19. 技术科普丨景深到底是什么
  20. 初步了解802.15.4协议与ZigBee

热门文章

  1. 将一个n位数分解为各个位数的数字。
  2. 如何用c语言编写炫酷烟花程序,C语言实现放烟花的程序
  3. Spring中@Primary注解
  4. 仿生多足机器人的发展和落地
  5. ElasticSearch之——Java操作ES实例(基于ES-2.3.0)
  6. Flex 分页预览,分页打印
  7. 源代码防泄密解决方案
  8. 【FPGA】初探FPGA —— 入门书籍推荐
  9. 机器学习在热门微博推荐系统的应用
  10. Python中将科学计数法(或以e为底的自然对数)字符串转换为float浮点数