进程占用cpu过高分析总结

2024-08-22 18:08

本文主要是介绍进程占用cpu过高分析总结,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

cpu排查过程记录

1. 使用top命令获取占用CPU最高的进程号

top
top - 10:21:31 up 783 days, 23:45,  1 user,  load average: 157.74, 144.77, 125.50
Tasks: 833 total,   5 running, 828 sleeping,   0 stopped,   0 zombie
Cpu(s): 48.5%us, 49.8%sy,  0.0%ni,  1.1%id,  0.0%wa,  0.0%hi,  0.6%si,  0.0%st
Mem:  132124464k total, 60951572k used, 71172892k free,    49348k buffers
Swap: 32767992k total,     1260k used, 32766732k free, 17250188k cachedPID USER      PR  NI  VIRT  RES  SHR S %CPU %MEM    TIME+  COMMAND                                                                                                             
63080 sms_pt    20   0 56.8g  14g  11m S 3030.6 11.2   7335:30 java                                                                                                               
34482 sms_pt    20   0 56.4g 6.0g  11m S 743.1  4.8 509:42.39 java                                                                                                                
54999 sms_pt    20   0 57.1g  14g  11m S 724.1 11.9   5422:52 java     

可以看到进程号63080的进程占用CPU瞬时值达到3000多。

2. 根据进程号查看线程信息

ps -o THREAD,tid.time -mp $PID
#输出的内容比较多,不一一列出,可以根据自己的需要进行排序
#可以按照自己的需求进行排序
#命令如下:
# ps -o THREAD,tid.time -mp $PID|sort -nk $列数
#为了能获取完整结果,建议重定向

我把CPU的占用时间进行排序,截取一部分内容显示

sms_pt    1.3  19    - poll_s    -      - 36638 00:10:36
sms_pt    1.3  19    - poll_s    -      - 36720 00:10:31
sms_pt    1.3  19    - poll_s    -      - 36861 00:10:32
sms_pt    1.3  19    - poll_s    -      - 36907 00:10:38
sms_pt    1.3  19    - poll_s    -      - 36995 00:10:28
sms_pt    1.3  19    - poll_s    -      - 37020 00:10:38
sms_pt    1.3  19    - poll_s    -      - 37087 00:10:30
sms_pt    1.3  19    - poll_s    -      - 37136 00:10:32
sms_pt    1.3  19    - poll_s    -      - 37142 00:10:32
sms_pt    1.3  19    - poll_s    -      - 37368 00:10:29
sms_pt    1.4  19    - poll_s    -      - 55366 00:14:12
sms_pt    1.5  19    - poll_s    -      - 56871 00:14:36
sms_pt    1.6  19    - ep_pol    -      - 54976 00:16:00
sms_pt    2.6  19    - ep_pol    -      - 55221 00:25:22
sms_pt    2.6  19    - ep_pol    -      - 55222 00:25:23
sms_pt    3.0  19    - -         -      - 36818 00:24:39
sms_pt    3.0  19    - poll_s    -      - 37148 00:24:29
USER     %CPU PRI SCNT WCHAN  USER SYSTEM   TID     TIME
sms_pt   11.5  19    - -         -      - 55223 01:52:28
sms_pt    798   -    - -         -      -     - 5-09:38:31

3 查看堆栈信息

#堆栈信息重定向到文件
jstack $PID >> $file_name
#在堆栈信息里面tid(线程号)是用16进制显示,先将线程号转为16进制
$ printf "%x\n" 37148
911c
$ grep "911c" -A20 $filename
"http-nio-20002-exec-714" daemon prio=10 tid=0x00007f6250343800 nid=0x911c waiting on condition [0x00007f5e02221000]java.lang.Thread.State: TIMED_WAITING (parking)at sun.misc.Unsafe.park(Native Method)- parking to wait for  <0x0000000086a80be8> (a java.util.concurrent.locks.AbstractQueuedSynchronizer$ConditionObject)at java.util.concurrent.locks.LockSupport.parkNanos(LockSupport.java:226)at java.util.concurrent.locks.AbstractQueuedSynchronizer$ConditionObject.awaitNanos(AbstractQueuedSynchronizer.java:2082)at java.util.concurrent.LinkedBlockingQueue.poll(LinkedBlockingQueue.java:467)at org.apache.tomcat.util.threads.TaskQueue.poll(TaskQueue.java:86)at org.apache.tomcat.util.threads.TaskQueue.poll(TaskQueue.java:32)at java.util.concurrent.ThreadPoolExecutor.getTask(ThreadPoolExecutor.java:1068)at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1130)at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:615)at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61)at java.lang.Thread.run(Thread.java:745)

给开发反馈之后,mq占用CPU资源比较多,已经在修改。

4. 根据自己的需要统计信息

统计线程的运行状态

# 这样会返回所有的状态
grep "java.lang.Thread.State:" $filename|awk '{print $2}'
#稍微改一下获取统计结果
$ grep "java.lang.Thread.State:" $filename|awk '{++s[$2]}END{for( a in s ) print s[a],a}'
7 WAITING
790 TIMED_WAITING
2 BLOCKED
299 RUNNABLE

这篇关于进程占用cpu过高分析总结的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1097013

相关文章

Linux进程CPU绑定优化与实践过程

《Linux进程CPU绑定优化与实践过程》Linux支持进程绑定至特定CPU核心,通过sched_setaffinity系统调用和taskset工具实现,优化缓存效率与上下文切换,提升多核计算性能,适... 目录1. 多核处理器及并行计算概念1.1 多核处理器架构概述1.2 并行计算的含义及重要性1.3 并

Linux下进程的CPU配置与线程绑定过程

《Linux下进程的CPU配置与线程绑定过程》本文介绍Linux系统中基于进程和线程的CPU配置方法,通过taskset命令和pthread库调整亲和力,将进程/线程绑定到特定CPU核心以优化资源分配... 目录1 基于进程的CPU配置1.1 对CPU亲和力的配置1.2 绑定进程到指定CPU核上运行2 基于

MySQL中的LENGTH()函数用法详解与实例分析

《MySQL中的LENGTH()函数用法详解与实例分析》MySQLLENGTH()函数用于计算字符串的字节长度,区别于CHAR_LENGTH()的字符长度,适用于多字节字符集(如UTF-8)的数据验证... 目录1. LENGTH()函数的基本语法2. LENGTH()函数的返回值2.1 示例1:计算字符串

Android kotlin中 Channel 和 Flow 的区别和选择使用场景分析

《Androidkotlin中Channel和Flow的区别和选择使用场景分析》Kotlin协程中,Flow是冷数据流,按需触发,适合响应式数据处理;Channel是热数据流,持续发送,支持... 目录一、基本概念界定FlowChannel二、核心特性对比数据生产触发条件生产与消费的关系背压处理机制生命周期

Javaee多线程之进程和线程之间的区别和联系(最新整理)

《Javaee多线程之进程和线程之间的区别和联系(最新整理)》进程是资源分配单位,线程是调度执行单位,共享资源更高效,创建线程五种方式:继承Thread、Runnable接口、匿名类、lambda,r... 目录进程和线程进程线程进程和线程的区别创建线程的五种写法继承Thread,重写run实现Runnab

Java通过驱动包(jar包)连接MySQL数据库的步骤总结及验证方式

《Java通过驱动包(jar包)连接MySQL数据库的步骤总结及验证方式》本文详细介绍如何使用Java通过JDBC连接MySQL数据库,包括下载驱动、配置Eclipse环境、检测数据库连接等关键步骤,... 目录一、下载驱动包二、放jar包三、检测数据库连接JavaJava 如何使用 JDBC 连接 mys

怎样通过分析GC日志来定位Java进程的内存问题

《怎样通过分析GC日志来定位Java进程的内存问题》:本文主要介绍怎样通过分析GC日志来定位Java进程的内存问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、GC 日志基础配置1. 启用详细 GC 日志2. 不同收集器的日志格式二、关键指标与分析维度1.

Java进程异常故障定位及排查过程

《Java进程异常故障定位及排查过程》:本文主要介绍Java进程异常故障定位及排查过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、故障发现与初步判断1. 监控系统告警2. 日志初步分析二、核心排查工具与步骤1. 进程状态检查2. CPU 飙升问题3. 内存

JavaSE正则表达式用法总结大全

《JavaSE正则表达式用法总结大全》正则表达式就是由一些特定的字符组成,代表的是一个规则,:本文主要介绍JavaSE正则表达式用法的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参考下... 目录常用的正则表达式匹配符正则表China编程达式常用的类Pattern类Matcher类PatternSynta

MySQL中的表连接原理分析

《MySQL中的表连接原理分析》:本文主要介绍MySQL中的表连接原理分析,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、背景2、环境3、表连接原理【1】驱动表和被驱动表【2】内连接【3】外连接【4编程】嵌套循环连接【5】join buffer4、总结1、背景