使用自动化shell脚本查找CPU使用的详细线程信息

项目加了些拦截器代码后,CPU报警,显示CPU使用率超过100%;

想要查找到底是哪些代码消耗的资源过多,从网上找到一篇博文,转载如下:

http://blog.csdn.net/guixunlong/article/details/8450897


在知道哪个Java进程CPU占用率过高以后:

1.使用命令 jstack PID 命令打印出CPU占用过高进程的线程栈,例如jstack 12012 > 12012.txt

2.使用top -H -p PID 命令查看对应进程是哪个线程占用CPU过高. 比如:

可以看到,线程号为12025的线程占用cpu很高,接下来就可以在12012.txt中查找该线程,看它为啥这么忙了

或者也可以采用ps命令 ps -mp pid -o THREAD,tid,time 或者 ps -Lfp pid 来查看繁忙的线程信息

这个命令的作用,主要是可以获取到对应一个进程下的线程的一些信息。

比如你想分析一下一个java进程的一些运行瓶颈点,可以通过该命令找到所有当前Thread的占用CPU的时间,线程号为tid列。

3.在jstack dump出来的文件中查找目录线程,需要注意的是用16进程数来表示线程号,所以我们可以找12025对应的16进程数2EF9

图中黄色文字即为线程id值

nid : 对应的Linux操作系统下的tid线程号,也就是前面转化的16进制数字

tid: 这个应该是jvm的jmm内存规范中的唯一地址定位

按照博主的步骤,的确找到的详细的线程信息(非常感谢博主!)。

只是步骤有些繁琐,在紧急时刻,分秒必争,该方法显然会浪费不少时间。

于是想根据博主的步骤,写个自动化的脚本。

经过多次的执行和分析,功夫不负有心人,终于写出了满足条件的shell脚本,

直接调用该脚本,无需任何参数,即可执行;该脚本能在笔者工作的各个生产环境中使用。

现将该脚本内容贴出如下,并在代码中添加了注释,供各位参考;该脚本不一定满足各种环境,请自行修改。

笔者水平有限,错误在所难免。欢迎批评指正。

#!/bin/bash

########################################################
### 查找占用CPU资源过高的线程详细信息
###
### 2014-11-03 allen add
##########################################################

#Step1 打印占用CPU过高的进程ID
top -b -d3 -n1 -u hotel | awk ‘/PID/,0‘ > ./_pid_out.out
v_pid=`awk ‘NR==2 {print $1}‘ ./_pid_out.out`

#Step2 打印进程中占用CPU过高的线程ID
top -b -d3 -n1 -H -p $v_pid | awk ‘/PID/,0‘ > ./_tid_out.out
v_tid=`awk ‘NR==2 {print $1}‘ ./_tid_out.out`

#Step3 将线程ID转为16进制
#echo ‘ibase=10;obase=16;$v_tid‘ | bc
v_tid16=`printf %x $v_tid`
echo "thread id[hexadecimal] is : 0x${v_tid16}"
echo ""

#Step4 打印CPU占用过高的进程的线程栈
echo "wait 5 seconds, please..."
jstack $v_pid > ./_thread_stack.out
sleep 5s

#Step5 在 _thread_stack.out 中查找线程执行的具体代码,打印改行及其之后30行,并高亮显示匹配内容
cat ./_thread_stack.out | grep -n --color=auto -A 30 -i 0x${v_tid16}

#clean
rm -rf ./_pid_out.out
rm -rf ./_tid_out.out
时间: 2024-10-27 13:45:26

使用自动化shell脚本查找CPU使用的详细线程信息的相关文章

【转】Java 连接远程Linux 服务器执行 shell 脚本查看 CPU、内存、硬盘信息

pom.xml jar 包支持 <dependency> <groupId>com.jcraft</groupId> <artifactId>jsch</artifactId> <version>0.1.53</version> </dependency> 代码: package com.spring.bean.annotation; import java.io.BufferedReader; import

&lt;zz&gt;linux运维自动化shell脚本小工具

from http://www.cnblogs.com/wang-li/p/5728461.html linux运维shell 脚本小工具,如要分享此文章,请注明文章出处,以下脚本仅供参考,若放置在服务器上出错,后果请自负 1.检测cpu剩余百分比 #!/bin/bash #Inspect CPU #Sun Jul 31 17:25:41 CST 2016 PATH=/usr/local/bin:/bin:/usr/bin:/usr/local/sbin:/usr/sbin:/sbin:/hom

linux运维自动化shell脚本小工具

linux运维shell 脚本小工具,如要分享此文章,请注明文章出处,以下脚本仅供参考,若放置在服务器上出错,后果请自负 1.检测cpu剩余百分比 #!/bin/bash #Inspect CPU #Sun Jul 31 17:25:41 CST 2016 PATH=/usr/local/bin:/bin:/usr/bin:/usr/local/sbin:/usr/sbin:/sbin:/home/wl/bin export PATH TERM=linux export TERM CpuResu

shell脚本采集系统cpu、内存、磁盘、网络信息

有不少朋友不知道如何用shell脚本采集linux系统相关信息,包括cpu.内存.磁盘.网络等信息,这里脚本小编做下讲解,大家一起来看看吧. 一.cpu信息采集 1),采集cpu使用率采集算法:通过/proc/stat文件采集并计算CPU总使用率或者单个核使用率.以cpu0为例,算法如下: 1,cat /proc/stat | grep ‘cpu0'得到cpu0的信息 2,cpuTotal1=user+nice+system+idle+iowait+irq+softirq 3,cpuUsed1=

前端自动化 shell 脚本命令 与 shell-node 脚本命令 简单使用 之 es6 转译

(背景: 先用 babel 转译 es6 再 用 browserify 打包 模块化文件,来解决浏览器不支持模块化 )(Browserify是一个让node模块可以用在浏览器中的神奇工具) 今天折腾了一上午,对于前端好多自动化管理的命令用起来,步骤甚多,故想写一个脚本文件,将项目所需要执行到命令 都 写在一个脚本文件中,在命令行 只需写一个命令即 完成所有事情.配置的环境: node + git1.第一步:在项目根目录下 新建 package.json 配置文件 { "name": &

Linux shell 脚本监控cpu,内存,硬盘,网络,是否存活

写脚本的背景:脚本实现简单的监控,而不需要用非常的重的监控软件完成. 脚本如下 #!/bin/sh # 脚本放入到/usr/local/bin # chmod 755 check_server.sh # crontab 中添加 source /etc/bashrc #------监控阈值 DISK_space_warn=90 CPU_load_warn=5 CPU_use_warn=50 MEM_use_warn=95 #SWAP_use_warn=50 Net_SYN_count_warn=2

Shell脚本监控CPU、内存和硬盘利用率

1.监控CPU利用率(通过vmstat工具) #!/bin/bash#====================================================# Author: lizhenliang - EMail:[email protected]# Create Date: 2015-02-01# Description: cpu utilization monitor# blog:lizhenliang.blog.51cto.com#===================

centos7.2,shell脚本监控CPU并sendmail自动报警

操作系统:centos 7.2 sendmail 自动报警#完成时间:2018.04.16 #!/bin/bash #CPU 1,5,15###########################################################if [ -e detection_script ]thenmkdir -p /detection_script/fi############################################################dt=

使用Shell脚本查找程序对应的进程ID,并杀死进程

#!/bin/sh NAME=$1echo $NAMEID=`ps -ef | grep "$NAME" | grep -v "$0" | grep -v "grep" | awk '{print $2}'`echo $IDecho "---------------"for id in $IDdokill -9 $idecho "killed $id"doneecho "-------------