cpu分析简介

论坛 期权论坛 脚本     
已经匿名di用户   2021-11-29 16:42   3280   0

进程占用CPU过高,一般有以下两种原因:
1、 业务量过大导致进程处理负荷高,占用CPU资源;
2、 程序BUG导致,比如死循环;
初步查看cpu占用情况
top
进一步分析
对于程序陷入死循环导致CPU占用过高类问题,最好的办法是把进程当前的堆栈信息打印出来,根据堆栈找到代码,快速定位出问题。
Step1:查看线程占用CPU的情况
ps -mp 2651 -o THREAD,tid,time | sort -rn
Step2:查看CPU占用高的线程堆栈
找出CPU消耗最多的线程ID,并将线程ID转换为16进制,最后使用jstack工具打印线程堆栈信息
printf "%x\n" 3850
jstack 2651 | grep f0a -A 30

分享到 :
0 人收藏
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

积分:81
帖子:4969
精华:0
期权论坛 期权论坛
发布
内容

下载期权论坛手机APP