分析定位占用CPU资源高的JVM线程

1 篇文章 0 订阅

分析定位占用CPU资源高的JVM线程

1.  获得高负载的进程号pid :  ps -ef | grep java

2.  执行shell 脚本(topthread.sh)来分析定位占用CPU资源的线程;

3.  分析线程对应的代码片段来优化修复问题.


topthread.sh 脚本(带参pid)片段: 

#!/bin/sh
export LANG="zh_CN.UTF-8";
export LC_ALL="zh_CN.UTF-8";

LOG_DIR="/tmp/";
LOG_FILE="_thread.log";
JSTACK_FILE="_jstack.log";

PID="$1";
shift;
i=0;
topline=20;

if [ -z "${PID}" ]; then
    exit "pid is empty.";
fi

if [[ "$2" =~ ^[0-9]+$ ]]; then
    topline="$2";
fi

LOG_FILE= ${LOG_DIR}${PID}${LOG_FILE};
JSTACK_FILE= ${LOG_DIR}${PID}${JSTACK_FILE};

ps -mp ${PID} -o THREAD,tid,time | sort -rn > ${LOG_FILE};
jstack ${PID} > ${JSTACK_FILE};

for LINE in `cat ${LOG_FILE}|gawk -F '-' '{print $4}'|gawk -F ' ' '{print $1}'`
do
    i=$(($i+1));
    if (($i>$topline)); then
        break;
    fi;
    XPID=`printf "%x\n" ${LINE}`;
    echo -ne "\033[32m";
    echo ${XPID};
    echo -e "\033[34m";
    grep -A 10 "0x${XPID}" ${JSTACK_FILE};
    echo -e "\e[0m";
done;

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值