排查linux下java应用cpu占用太高

用于快速排查JavaCPU性能问题(top us值太高),自动查出运行的Java进程中消耗CPU多的线程,并打印出其线程栈,从而肯定致使性能问题的方法调用。
目前只支持Linux。缘由是MacWindowsps命令不支持列出进程的线程id,更多信息参见#33,欢迎提供解法。java

PS,如何操做能够参见@bluedavy《分布式Java应用》的【5.1.1 CPU消耗分析】一节,说得很详细:git

  1. top命令找出消耗CPU高的Java进程及其线程id
    1. 开启线程显示模式(top -H,或是打开top后按H
    2. CPU使用率排序(top缺省是按CPU使用降序,已经合要求;打开top后按P能够显式指定按CPU使用降序)
    3. 记下Java进程id及其CPU高的线程id
  2. 查看消耗CPU高的线程栈:
    1. 用进程id做为参数,jstack出有问题的Java进程
    2. 手动转换线程id成十六进制(能够用printf %x 1234
    3. jstack输出中查找十六进制的线程id(能够用vim的查找功能/0x1234,或是grep 0x1234 -A 20
  3. 查看对应的线程栈,分析问题

查问题时,会要屡次上面的操做以分析肯定问题,这个过程太繁琐太慢了。github

 

 

转自:https://github.com/oldratlee/useful-scripts/blob/master/docs/java.md#-show-busy-java-threadsvim

相关文章
相关标签/搜索