用于快速排查Java
的CPU
性能问题(top us
值太高),自动查出运行的Java
进程中消耗CPU
多的线程,并打印出其线程栈,从而肯定致使性能问题的方法调用。
目前只支持Linux
。缘由是Mac
、Windows
的ps
命令不支持列出进程的线程id
,更多信息参见#33,欢迎提供解法。java
PS,如何操做能够参见@bluedavy的《分布式Java应用》的【5.1.1 CPU
消耗分析】一节,说得很详细:git
top
命令找出消耗CPU
高的Java
进程及其线程id
:
top -H
,或是打开top
后按H
)CPU
使用率排序(top
缺省是按CPU
使用降序,已经合要求;打开top
后按P
能够显式指定按CPU
使用降序)Java
进程id
及其CPU
高的线程id
CPU
高的线程栈:
id
做为参数,jstack
出有问题的Java
进程id
成十六进制(能够用printf %x 1234
)jstack
输出中查找十六进制的线程id
(能够用vim
的查找功能/0x1234
,或是grep 0x1234 -A 20
)查问题时,会要屡次上面的操做以分析肯定问题,这个过程太繁琐太慢了。github
转自:https://github.com/oldratlee/useful-scripts/blob/master/docs/java.md#-show-busy-java-threadsvim