linux环境java程序cpu爆表问题查证

1.top命令查找导致cup爆表的进程

2. top -H -p10832 (10832是Java进程的PID)命令找出了具体的线程

3.使用用命令 jstack 10832> jstack.txt (10832是Java进程的PID)打印出了Java进程的堆栈信息放到jstack.txt文件了;

由于堆栈打印的线程的native id是十六机制的,所以,我把十进制的线程id(6904、6905、6906、6907)转化成十六进制(0x1af8、0x1af9、0x1afa、0x1afb);最后,通过 cat jstack.txt | grep -C 20 0x1af8 命令找到了具体的线程信息

4.使用命令 jstat -gcutil 10832 2000 10 (10832是Java进程的PID)来观察GC的运行信息

5.使用命令 jmap -histo 10832 (10832 是Java进程的PID)打印出了Java的内存占用信息

友情提示:

jstack是JDK内置的堆栈跟踪工具,位于JDK根目录的bin文件夹下面,可用于打印的Java堆栈信息。

jstat是JDK内置的JVM检测统计工具,位于JDK根目录的bin文件夹下面,可以对堆内存的使用情况进行实时统计。

jmap是JDK内置的内存映射工具,位于JDK根目录的bin文件夹下面,可用于获取java进程的内存映射信息。

除了本文提及的jvisualvm、jstack、jstat、jmap这些工具,在JDK根目录的bin文件夹下面还有其他许多非常有用的工具,例如:使用 jinfo 查看Java进程相关信息

原文地址:https://www.cnblogs.com/guangxiang/p/11490600.html