`

CPU load过高产生的原因及排查(转)

    博客分类:
  • JVM
 
阅读更多

转自:http://m.blog.csdn.net/canot/article/details/78079085

 

什么是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进制的表示。


分享到:
评论

相关推荐

    mysql CPU高负载问题排查

    MySQL导致的CPU高负载问题  今天下午发现了一个MySQL导致的向上服务器负载高的问题,事情的背景如下:  在某个新服务器上,新建了一个MySQL的实例,该服务器上面只有MySQL这一个进程,但是CPU的负载却居高不下,...

    Linux系统cpu,内存高负载排查-云主机-产品文档-帮助文档-京东云.pdf

    对于CPU使用率低但负载高的情况,问题可能出在“负载平均”(load average)上。负载平均值反映了在一段时间内系统中平均有多少任务在等待CPU处理。如果系统空闲,但负载平均值很高,这可能意味着存在僵死进程(D...

    DM642 CPU load 占用率

    - **优化算法**:如果发现某些任务导致CPU负载过高,可以考虑优化相关算法,减少不必要的计算。 - **调整任务调度**:合理分配不同任务的执行优先级和时间片,确保系统响应性和稳定性。 - **硬件资源分配**:理解CPU...

    Linux系统问题排查

    1. **CPU使用率过高** - **现象**: CPU使用率持续处于高位。 - **原因分析**: - 用户进程占用过多。 - I/O等待过高。 - 内核处理消耗过多CPU。 - **排查方法**: - 使用`top`命令查看CPU使用率最高的进程。 -...

    freertos下的cpu占用率统计.zip

    在使用RTOS时,了解系统的CPU占用率是非常重要的,它可以帮助我们评估系统的性能、优化任务调度以及排查潜在的瓶颈。"freertos下的cpu占用率统计.zip"文件提供了一种在FreeRTOS环境下统计CPU占用率的方法,这种方法...

    http_load测试工具

    1. **性能瓶颈识别**:通过http_load的结果分析,可以发现服务器在高并发下的瓶颈,如CPU、内存、网络I/O等。 2. **配置调整**:根据测试数据,可以优化Web服务器的配置,如调整Nginx或Apache的连接数限制、超时设置...

    详解Linux中Load_average负载

    - 如果发现负载过高,可以考虑优化应用程序、增加硬件资源或重新配置系统参数。 - 对于持续性的高负载,应该深入分析具体原因并采取相应措施,比如限制某些进程的资源消耗、升级硬件等。 #### 七、总结 理解...

    线上问题排查工具和手段

    在案例二中,观察到服务器load过高,有宕机的趋势。通过日志分析、监控数据和使用各种系统工具,可以找到问题的根本原因,从而采取相应的措施解决问题。 总之,线上问题的排查工具和手段多样,从日志分析到系统监控...

    pathload2客户端程序源代码

    - **CPU亲和性**:为了减少上下文切换的开销,Pathload2可能将线程绑定到特定CPU核心上。 5. **日志和调试**: - **日志系统**:Pathload2可能包含一个日志系统,记录运行过程中的关键信息,便于问题排查。 - **...

    线上问题排查

    - **Load**:系统负载指的是单位时间内 CPU 正在处理以及等待 CPU 处理的进程数之和的统计信息,安全的负载值一般等于 CPU 核心数。 - **工具与命令** - **`uptime` / `w`**:用于查看系统运行时间、当前登录...

    31条MIPS指令单周期CPU

    2. **加载/存储指令**:如load word(lw)用于从内存加载数据到寄存器,store word(sw)则将寄存器中的数据存储到内存。 3. **分支指令**:如beq(条件分支,当两个寄存器相等时跳转)、bne(不相等时分支)、jal...

    一个非常简单的CPU的设计.rar

    在这个案例中,CPU有4条指令,虽然具体指令未给出,但常见的基础指令可能包括加载(Load)、存储(Store)、算术运算(Add或Subtract)以及跳转(Jump)等。 2. **逻辑门**:CPU由基本的逻辑门电路构建,如AND、OR...

    查看CPU和内存的实验

    在IT领域,了解CPU和内存的使用情况是至关重要的,特别是在进行系统优化或者问题排查时。这个实验将带你深入理解如何通过机器指令和汇编语言来查看这些关键资源的状态。让我们详细探讨一下这两个主题。 首先,CPU...

    01-cpu性能优化.pptx

    例如,`mpstat`可以实时监测每个CPU核心的利用率,帮助识别哪个核心负担过重。`pidstat`则可以追踪特定进程的CPU、内存和I/O性能,找出资源消耗大户。此外,通过分析`/proc/interrupts`文件,可以获取中断统计信息,...

    Load runner 8.1中文教程

    【Load Runner 8.1中文教程】是一份深入解析HP LoadRunner 8.1版本的综合性教程,旨在帮助用户掌握这一强大的性能测试工具。LoadRunner是业界广泛使用的应用性能测试软件,尤其在企业级系统中,它能模拟大量并发用户...

    CPU占用100% 案例分析.pdf

    若该进程占用过高,可能是由于恶意软件或“木马”程序的感染。检查win.ini、system.ini文件以及注册表中的启动项是排查问题的关键。 - **win.ini**:检查[Windows]部分的"run="和"load=",确保没有未知的启动文件...

    Windows 操作系统的 CPU 使用率:获取 Windows 操作系统的 CPU 负载-matlab开发

    这将帮助你了解系统在执行特定任务时的CPU负载变化,从而优化程序性能或进行故障排查。 总的来说,通过MATLAB与系统接口的交互,我们可以有效地获取和分析Windows操作系统的CPU使用率,即使在遇到WMIC不兼容问题时...

Global site tag (gtag.js) - Google Analytics