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