美文网首页
show-busy-java-threads排查CPU性能问题

show-busy-java-threads排查CPU性能问题

作者: 羋学僧 | 来源:发表于2022-05-26 14:31 被阅读0次

show-busy-java-threads排查CPU性能问题

show-busy-java-thread用于快速排查Java的CPU性能问题(top us值过高),自动查出运行的JAVA进程中消耗CPU多的线程,并打印出其线程栈,从而确定导致性能问题的方法调用。

一、以往方法

1. top命令找出消耗CPU高的Java进程及其线程id:

i. 开启线程的显示模式(top -H,或者打开top后按H)。
ii. 按cpu使用率排序(top缺省就是按CPU的使用率降序)。
iii. 记下Java进程id及其CPU高的线程id。

2. 查看消耗CPU高的线程栈:

i. 用进程id作为参数,jstack出有问题的Java进程。
ii. 手动转换线程id成16进制(可以使用printf %x pid)。
iii. 在jstack输出中查找16进制的线程id(jstack -l pid > test.txt | grep16进制的值)

3. 查看对应的线程栈,分析问题。

查问题时,会要多次上面的操作以分析确定问题,这个过程太繁琐太慢了。

二、show-busy-java-threads命令

注意:show-busy-java-threads只支持Linux服务器

2.1 安装

推荐使用直接在网络上下载安装包,并解压的方式。

## 下载安装包
source-shell
wget --no-check-certificate https://github.com/oldratlee/useful-scripts/archive/release.zip
## 解压
unzip release.zip

其他方式可参考:GitHub上show-busy-java-threads安装方式

2.2 常用命令

使用方式:sh show-busy-java-threads.sh

2.2.1 基本命令

# 从所有运行的Java进程中找出最消耗CPU的线程(缺省5个),打印出其线程栈
show-busy-java-threads

# 缺省会自动从所有的Java进程中找出最消耗CPU的线程,这样用更方便
# 当然你可以手动指定要分析的Java进程Id,以保证只会显示你关心的那个Java进程的信息
show-busy-java-threads -p <指定的Java进程Id>

show-busy-java-threads -c <要显示的线程栈数>

# 多次执行
show-busy-java-threads <重复执行的间隔秒数> [<重复执行的次数>]

# 记录到文件以方便回溯查看
show-busy-java-threads -a <运行输出的记录到的文件>

# 指定jstack输出文件的存储目录,方便记录以后续分析
show-busy-java-threads -S <存储jstack输出文件的目录>

2.2.2 注意事项

# 如果Java进程的用户 与 执行脚本的当前用户 不同,则jstack不了这个Java进程
# 为了能切换到Java进程的用户,需要加sudo来执行,即可以解决:
sudo show-busy-java-threads

# 对于sudo方式的运行,JAVA_HOME环境变量不能传递给root,
# 而root用户往往没有配置JAVA_HOME且不方便配置,
# 显式指定jstack命令的路径就反而显得更方便了
show-busy-java-threads -s <指定jstack命令的全路径>

2.2.3 其他命令

# -m选项:执行jstack命令时加上-m选项,显示上Native的栈帧,一般应用排查不需要使用
show-busy-java-threads -m
# -F选项:执行jstack命令时加上 -F 选项(如果直接jstack无响应时,用于强制jstack),一般情况不需要使用
show-busy-java-threads -F
# -l选项:执行jstack命令时加上 -l 选项,显示上更多相关锁的信息,一般情况不需要使用
# 注意:和 -m -F 选项一起使用时,可能会大大增加jstack操作的耗时
show-busy-java-threads -l

推荐阅读

show-busy-java-threads的github地址

相关文章

网友评论

      本文标题:show-busy-java-threads排查CPU性能问题

      本文链接:https://www.haomeiwen.com/subject/ohwuprtx.html