java调试工具

jps
当前用户已启动的java进程信息,信息包括进程号和简短的进程command。


jstat
输出指定 jvm 实例的特定统计量:
统计量:
-class
-compiler
-gc
-gccapacity
-gccause
-gcnew
-gcnewcapacity
-gcold
-gcoldcapacity
-gcpermcapacity
-gcutil
-printcompilation

eg:
jstat -gcutil 161637

jstack
显示指定 jvm 实例的当前线程运行栈信息,可查看各个线程当前状态及调用序列。
-l 打印锁的附加信息
-F 强制输出

jmap
显示指定 jvm 实例的堆状态,可用于 dump 当前堆信息,用于离线分析,对排查内存问题很有帮助。
jmap -dump:file=/tmp/fmt.bin 44777

jhat
是用来分析java堆的命令,和jmap配合使用。可以将堆中的对象以html的形式显示出来,包括对象的数量,大小等等,并支持对象查询语言
jhat fmt.bin

注意点:
java程序启动后,默认(请注意是默认)会在/tmp/hsperfdata_userName目录下以该进程的id为文件名新建文件,并在该文件中存储jvm运行
的相关信息,其中的userName为当前的用户名,/tmp/hsperfdata_userName目录会存放该用户所有已经启动的java进程信息。
而jps、jconsole、jvisualvm等工具的数据来源就是这个文件(/tmp/hsperfdata_userName/pid)。所以当该文件不存在或是无法读取时就会
出现jps无法查看该进程号,jconsole无法监控等问题

原文地址:https://www.cnblogs.com/wully/p/3404063.html