jstack(查看线程)、jmap(查看内存)、jstat(性能分析)
jstack pid
jmap pid
jmap -dump:[live,]format=b,file=heap.bin pid(导出内存,据说对性能有影响)
jmap -finalizerinfo 打印正等待回收的对象信息
jmap -heap 打印heap的概要信息,GC使用的算法,heap的配置及wise heap的使用情况
jmap -histo 打印每个class的实例数目,内存占用,类全名信息. VM的内部类名字开头会加上前缀”*”. 如果live子参数加上后,只统计活的对象数量.
jmap -permstat 打印classload和jvm heap长久层的信息. 包含每个classloader的名字,活泼性,地址,父classloader和加载的 class数量. 另外,内部String的数量和占用内存数也会打印出来
-F 强迫.在pid没有相应的时候使用-dump或者-histo参数. 在这个模式下,live子参数无效
-h 打印辅助信息
-J 传递参数给jmap启动的jvm
jstat
例:jstat -gc 进程号 5000(五秒刷一次)
-class:统计class loader行为信息
-compile:统计编译行为信息
-gc:统计jdk gc时heap信息
-gccapacity:统计不同的generations(不知道怎么翻译好,包括新生区,老年区,permanent区)相应的heap容量情况
-gccause:统计gc的情况,(同-gcutil)和引起gc的事件
-gcnew:统计gc时,新生代的情况
-gcnewcapacity:统计gc时,新生代heap容量
-gcold:统计gc时,老年区的情况
-gcoldcapacity:统计gc时,老年区heap容量
-gcpermcapacity:统计gc时,permanent区heap容量
-gcutil:统计gc时,heap情况