进程占用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

相关文章

Python中logging模块用法示例总结

《Python中logging模块用法示例总结》在Python中logging模块是一个强大的日志记录工具,它允许用户将程序运行期间产生的日志信息输出到控制台或者写入到文件中,:本文主要介绍Pyt... 目录前言一. 基本使用1. 五种日志等级2.  设置报告等级3. 自定义格式4. C语言风格的格式化方法

Spring 依赖注入与循环依赖总结

《Spring依赖注入与循环依赖总结》这篇文章给大家介绍Spring依赖注入与循环依赖总结篇,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录1. Spring 三级缓存解决循环依赖1. 创建UserService原始对象2. 将原始对象包装成工

SysMain服务可以关吗? 解决SysMain服务导致的高CPU使用率问题

《SysMain服务可以关吗?解决SysMain服务导致的高CPU使用率问题》SysMain服务是超级预读取,该服务会记录您打开应用程序的模式,并预先将它们加载到内存中以节省时间,但它可能占用大量... 在使用电脑的过程中,CPU使用率居高不下是许多用户都遇到过的问题,其中名为SysMain的服务往往是罪魁

MySQL中查询和展示LONGBLOB类型数据的技巧总结

《MySQL中查询和展示LONGBLOB类型数据的技巧总结》在MySQL中LONGBLOB是一种二进制大对象(BLOB)数据类型,用于存储大量的二进制数据,:本文主要介绍MySQL中查询和展示LO... 目录前言1. 查询 LONGBLOB 数据的大小2. 查询并展示 LONGBLOB 数据2.1 转换为十

Linux系统管理与进程任务管理方式

《Linux系统管理与进程任务管理方式》本文系统讲解Linux管理核心技能,涵盖引导流程、服务控制(Systemd与GRUB2)、进程管理(前台/后台运行、工具使用)、计划任务(at/cron)及常用... 目录引言一、linux系统引导过程与服务控制1.1 系统引导的五个关键阶段1.2 GRUB2的进化优

MySQL中优化CPU使用的详细指南

《MySQL中优化CPU使用的详细指南》优化MySQL的CPU使用可以显著提高数据库的性能和响应时间,本文为大家整理了一些优化CPU使用的方法,大家可以根据需要进行选择... 目录一、优化查询和索引1.1 优化查询语句1.2 创建和优化索引1.3 避免全表扫描二、调整mysql配置参数2.1 调整线程数2.

Android 缓存日志Logcat导出与分析最佳实践

《Android缓存日志Logcat导出与分析最佳实践》本文全面介绍AndroidLogcat缓存日志的导出与分析方法,涵盖按进程、缓冲区类型及日志级别过滤,自动化工具使用,常见问题解决方案和最佳实... 目录android 缓存日志(Logcat)导出与分析全攻略为什么要导出缓存日志?按需过滤导出1. 按

Linux中的HTTPS协议原理分析

《Linux中的HTTPS协议原理分析》文章解释了HTTPS的必要性:HTTP明文传输易被篡改和劫持,HTTPS通过非对称加密协商对称密钥、CA证书认证和混合加密机制,有效防范中间人攻击,保障通信安全... 目录一、什么是加密和解密?二、为什么需要加密?三、常见的加密方式3.1 对称加密3.2非对称加密四、

MySQL中读写分离方案对比分析与选型建议

《MySQL中读写分离方案对比分析与选型建议》MySQL读写分离是提升数据库可用性和性能的常见手段,本文将围绕现实生产环境中常见的几种读写分离模式进行系统对比,希望对大家有所帮助... 目录一、问题背景介绍二、多种解决方案对比2.1 原生mysql主从复制2.2 Proxy层中间件:ProxySQL2.3

在Java中实现线程之间的数据共享的几种方式总结

《在Java中实现线程之间的数据共享的几种方式总结》在Java中实现线程间数据共享是并发编程的核心需求,但需要谨慎处理同步问题以避免竞态条件,本文通过代码示例给大家介绍了几种主要实现方式及其最佳实践,... 目录1. 共享变量与同步机制2. 轻量级通信机制3. 线程安全容器4. 线程局部变量(ThreadL