之前面试被问到,造成CPU load过高的原因有哪些?如何快速排查其原因?
开一贴,总结该相关知识

什么是cpu load 值

top命令中显示的load average即为最近1分钟、5分钟和15分钟的系统平均负载。

系统平均负载被定义为在特定时间间隔内运行队列中(在CPU上运行或者等待运行多少进程)的平均进程数。如果一个进程满足以下条件则其就会位于运行队列中:

  • 它没有在等待I/O操作的结果
  • 它没有主动进入等待状态(也就是没有调用’wait’)
  • 没有被停止(例如:等待终止)

在Linux中,进程分为三种状态,一种是阻塞的进程blocked process(等待I/O设备的数据或者系统调),一种是可运行的进程runnable process,另外就是正在运行的进程running process。

进程可运行状态时,它处在一个运行队列run queue中,与其他可运行进程争夺CPU时间。 系统的load是指正在运行和准备好运行的进程的总数。比如现在系统有2个正在运行的进程,3个可运行进程,那么系统的load就是5。load average就是一定时间内的load数量。

什么因素构成了cpu load的大小

衡量CPU 系统负载的指标是load,load 就是对计算机系统能够承担的多少负载的度量,简单的说是进程队列的长度。请求大于当前的处理能力,会出现等待,引起load升高。
对于本文刚刚开头显示的 load average 0.21 0.10 0.03

很多人会这样理解负载均值:三个数分别代表不同时间段的系统平均负载(一分钟、五 分钟、以及十五分钟),它们的数字当然是越小越好。数字越高,说明服务器的负载越大,这也可能是服务器出现某种问题的信号。而事实不完全如此,是什么因素构成了负载均值的大小,以及如何区分它们目前的状况是 “好”还是“糟糕”?什么时候应该注意哪些不正常的数值?

回答这些问题之前,首先需要了解下这些数值背后的些知识。我们先用最简单的例子说明, 一台只配备一块单核处理器的服务器。

行车过桥

  一只单核的处理器可以形象得比喻成一条单车道。设想下,你现在需要收取这条道路的过桥费 — 忙于处理那些将要过桥的车辆。你首先当然需要了解些信息,例如车辆的载重、以及 还有多少车辆正在等待过桥。如果前面没有车辆在等待,那么你可以告诉后面的司机通过。 如果车辆众多,那么需要告知他们可能需要稍等一会。

  因此,需要些特定的代号表示目前的车流情况,例如:

  0.00 表示目前桥面上没有任何的车流。 实际上这种情况与 0.00 和 1.00 之间是相同的,总而言之很通畅,过往的车辆可以丝毫不用等待的通过。

  1.00 表示刚好是在这座桥的承受范围内。 这种情况不算糟糕,只是车流会有些堵,不过这种情况可能会造成交通越来越慢。
  
  超过 1.00,那么说明这座桥已经超出负荷,交通严重的拥堵。 那么情况有多糟糕? 例如 2.00 的情况说明车流已经超出了桥所能承受的一倍,那么将有多余过桥一倍的车辆正在焦急的等待。3.00 的话情况就更不妙了,说明这座桥基本上已经快承受不了,还有超出桥负载两倍多的车辆正在等待。
  上面的情况和处理器的负载情况非常相似。一辆汽车的过桥时间就好比是处理器处理某线程 的实际时间。Unix 系统定义的进程运行时长为所有处理器内核的处理时间加上线程在队列中等待的时间。

  和收过桥费的管理员一样,你当然希望你的汽车(操作)不会被焦急的等待。所以,理想状态 下,都希望负载平均值小于 1.00 。当然不排除部分峰值会超过 1.00,但长此以往保持这 个状态,就说明会有问题,这时候你应该会很焦急。
“所以你说的理想负荷为 1.00 ?”嗯,这种情况其实并不完全正确。负荷 1.00 说明系统已经没有剩余的资源了。在实际情况中 ,有经验的系统管理员都会将这条线划在 0.70。如果长期你的系统负载在 0.70 上下,那么你需要在事情变得更糟糕之前,花些时间了解其原因。

多核处理器: 系统还是以处理器的核心数量计算负载均值
在多核处理中,你的系统均值不应该高于处理器核心的总数量。继续针对上述的汽车过桥问题,如果是双核CPU,那么负载在2.0才是负载满额。如下是对于双核处理器的输出

uptime
17:57  up 22 days,  8:29, 3 users, load averages: 2.04 2.04 2.01
  • 1
  • 2

cpu load 过高原因以及排查

造成cpu load过高的原因.从编程语言层次上full gc次数的增大或死循环都有可能造成cpu load 增高

具体的排查一句话描述就是

首先要找到哪几个线程在占用cpu,之后再通过线程的id值在堆栈文件中查找具体的线程,看看出来什么问题。
  • 1

寻找最占CPU的进程

  • 通过命令 ps ux
  • 通过top -c命令显示进程运行信息列表 (按键P按CPU占有资源排序)

寻找最耗CPU的线程

  • top -Hp 进程ID 显示一个进程ID的线程运行信息列表 (按键P按CPU占有资源排序)
    如果该进程是java进程,需要具体查看是哪段代码造成的CPU负载过高,根据上述获得到的线程ID可以使用JDK下的jstack来查看堆栈。

由于在堆栈中线程id是用16进制表示的,因此可以将上述线程转化成16进制的表示。

jstack java进程id  | grep 16进制的线程id  -C5 --color

cpu负载过高产生的原因及排查相关推荐

  1. linux 排查cpu负载过高原因

    CPU负载查看方法: 使用vmstat查看系统维度的CPU负载 使用top查看进程维度的CPU负载 一.测试工具 1.使用 vmstat 查看系统纬度的 CPU 负载: 可以通过 vmstat 从系统 ...

  2. CPU负载过高的原因

    一 系统中创建了大量的线程,这些线程并发运行,而且工作负载都很重,过多的线程同时运行就会导致CPU负载过高 二 JVM频繁的Full GC,非常耗费CPU资源 2.1 频繁Full GC的原因 内存分 ...

  3. 利用 Arthas 精准定位 Java 应用 CPU 负载过高问题

    Arthas 官方社区正在举行征文活动,参加即有奖品拿哦~点击投稿 作者 | 张云翔 最近我们线上有个应用服务器有点上头,CPU总能跑到99%,我寻思着它流量也不大啊,为啥能把自己整这么累?于是我登上 ...

  4. 宝塔php的opcache模块未载入,宝塔面板CPU负载过高使用opcache扩展的解决方法

    宝塔Linux面板出现CPU负载过高怎么办?使用PHP opcache扩展加速PHP脚本,新手站长网来说说宝塔CPU负载高使用PHP扩展opcache的设置及解决方法: 宝塔面板CPU负载过高的解决方 ...

  5. 一次运维事故调查报告--cpu负载过高

    题记:只要时间足够,在开发期间偷得懒,运维期间总会在某个恰当的时机有大的坑等着,不是坑到自己就是坑到后来人 : 九月份的某个深夜,被电话吵醒,运维说线上某个版本的两个服务器由于系统资源耗尽(主要是系统 ...

  6. JVM性能优化之CPU负载过高

    本文来说下JVM性能优化之CPU负载过高的问题 文章目录 概述 程序测试 问题定位 本文小结 概述 一般性结论:一般来说,CPU占用高不高的问题,不是给定一个数值,例如90%以上就算高,以下就算正常, ...

  7. 线上服务器CPU负载过高的问题解决过程

    线上服务器CPU负载过高的问题解决过程 一.找到CPU占用过高进程 执行top命令,发现PID为12443的Java进程占用CPU高达350%,出现故障. 二.定位具体线程或代码 找到该进程后,接下来 ...

  8. 电脑CPU占用率高是什么原因造成的? 与解决方法

    电脑CPU占用率高是什么原因造成的? CPU占用率高的九种可能 1.防杀毒软件造成故障 由于新版的KV.金山.瑞星都加入了对网页.插件.邮件的随机监控,无疑增大了系统负担.处理方式:基本上没有合理的处 ...

  9. cpu负载很高而使用率很低的缘故

    cpu负载很高而使用率很低的缘故 可以用#hdparm  -tT   /dev/sda1       来测试 Timing cached reads:   4624 MB in  2.00 secon ...

最新文章

  1. shell中的条件表达式
  2. 计算机网络 | 应用层 :HTTP协议详解
  3. linux脚本文件个数,Linux上面执行mysql脚本判断文件个数
  4. 一款零注解API接口文档生成工具
  5. Java—Map集合详解(HashMap/Hashtable/LinkedHashMap/Properties/TreeMap/WeakHashMap/IdentityHashMap/EnumMap)
  6. python的排序方式
  7. C# VS 调试 动态加载的 DLL
  8. 小米回应设备被谷歌禁用;苹果中国宣布 2019 款 iPad 降价;Wine 5.0-rc4 发布 | 极客头条...
  9. bzoj 1009: [HNOI2008]GT考试(dp+kmp+矩阵快速幂)
  10. 用Calibre去除Kindle电子书的DRM版权限制
  11. 服务器每个月维护要1000元,5月24日服务器例行维护公告(已完成)
  12. freemaker word转html,ftl文件-word文档转化成ftl文件
  13. 手机浏览网页或打开app时莫名弹出支付宝领红包界面的原因及预防措施
  14. 秋季吃哪些食物可以改善心情?
  15. 关联分析:Apriori算法
  16. 【JetBrain】JetBrain系列软件设置背景图
  17. 在php中利用gd2库的函数创建水印
  18. bat写暴力破解系统密码
  19. SpringCloud 微服务开放平台接口
  20. html5 ios keychain,iOS10适配之Keychain读写失败

热门文章

  1. matlab 求矢量夹角_MATLAB:如何画南开大学校徽?
  2. c语言汇编6,C语言是如何转换成汇编语言的6个步骤带你解析
  3. css基础--vertical-align
  4. 微信小程序—调用imgSecCheck接口实现多张图片鉴黄,敏感过滤
  5. 《企业管理概论》在线平时作业2
  6. java-se项目--嗖嗖移动
  7. 阿里云CentOS 安装 Nginx
  8. 099 复习:中值定理习题之型二:有ξ,有a,b ,型三: 有ξ,η
  9. TNF抑制剂在10例新近起病的难治性反应性关节炎患者中的安全性与疗效
  10. 利用二极管,三极管,电容,电阻设计一个扩音器