当前位置: 首页 > 工具软件 > CUP > 使用案例 >

cup飙高怎么排查和处理

谷梁镜
2023-12-01

01 CPU飙高系统反应慢怎么排查?

CPU是整个电脑的核心计算资源,对于一个应用进程来说,CPU的最小执行单元是线程

产生原因
(1) CPU资源过度消耗,也就是在程序中创建了大量的线程,或有线程一直占用CPU资源无法被释放,比如死循环!

   CPU利用率过高之后,导致应用中的线程无法获得CPU的调度,从而影响程序的执行效率!

(2) CPU上下文切换过多,对于CPU来说,同一时刻下每个CPU核心只能运行一个线程,若有多个线程要执行,CPU只能通过上下文切换的方式来执行不同的线程。上下文切换需要做两个事情

  1. 保存运行线程的执行状态

  2. 让处于等待中的线程执行

    这两个过程需要CPU执行内核相关指令实现状态保存,如果较多的上下文切换会占据大量CPU资源,从而使得cpu无法去执行用户进程中的指令,导致响应速度下降
    ,文件IO/网络IO/锁等待/线程阻塞等操作都会造成线程阻塞从而触发上下文切换

解决办法

(1) 可以通过top命令,找到CPU利用率较高的进程,再通过Shift+H找到进程中CPU消耗过高的线程,这里有两种情况

     CPU利用率过高的线程是同一个,说明程序中存在线程长期占用CPU没有释放的情况,这种情况直接通过jstack获得线程的Dump日志,定位到线程日志后就可以找到问题的代码
     CPU利用率过高的线程id不断变化,说明线程创建过多,需要挑选几个线程id,通过jstack去线程dump日志中排查。

(2) 有可能定位的结果是程序正常,只是在CPU飙高的那一刻,用户访问量较大,导致系统资源不够

 类似资料: