排查java程序中CPU飙高问题的代码定位

目录

1. 输入jps -lm 和 top 找到当前jar的进程pid

2. 查看当前进程的cpu消耗

3. 获取进程的线程的16进制的Tid 

4. 打印线程的堆栈信息

5. 一键使用脚本exec.sh


1. 输入jps -lm 和 top 找到当前jar的进程pid

        当前pid为25589

jps -lm|grep function

2. 查看当前进程的cpu消耗

top -p 25589

 

3. 获取进程的线程的16进制的Tid 

        根据CPU占用率选择最高的tid 这里是63f6

printf "cpu\t TID\n"
# 进程为25589
ps -mp 25589 -o THREAD,tid,time |awk '{print $2,$8}' | grep -v "TID" | grep -v "-"| awk '{printf "%d%%\t %x\n", $1, $2}' | sort -rn | head -10

4. 打印线程的堆栈信息

jstack 25589 | grep 63f6 -A60

5. 一键使用脚本exec.sh

# 输入参数为进程Id或者输入 进程Id与线程Tid 示例  sh exec.sh 25589 或者 sh exec.sh 25589 63f6
if [ -z "$2" ]; then
    if [ -z "$1" ]; then
        echo "请输入排查的进程Pid"
        exit
    fi
    printf "cpu\t TID\n"
    ps -mp $1 -o THREAD,tid,time |awk '{print $2,$8}' | grep -v "TID" | grep -v "-"| awk '{printf "%d%%\t %x\n", $1, $2}' | sort -rn | head -10
else
  jstack $1 | grep $2 -A60
fi

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小钻风巡山

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值