在Java应用和服务出现莫名的卡顿、CPU飙升等问题时老是要分析一下对应进程的JVM状态以定位问题和解决问题并做出相应的优化,在这过程当中Java自带的一些状态监控命令和图形化工具就很是方便了。本文总结了最经常使用的命令行工具及其经常使用参数解释,图形化监控工具的用法,仅供参考。java
Java版的ps命令,查看java进程及其相关的信息,若是你想找到一个java进程的pid,那能够用jps命令替代linux中的ps命令了,简单而方便。linux
命令格式:bash
jps [options] [hostid]
服务器
options参数解释:jvm
最经常使用示例:工具
jps -l 输出jar包路径,类全名 jps -m 输出main参数 jps -v 输出JVM参数
jinfo是用来查看JVM参数和动态修改部分JVM参数的命令性能
命令格式:学习
jinfo [option] <pid>测试
options参数解释:优化
最经常使用示例:
其中11666为pid
查看JVM参数和系统配置
jinfo 11666 jinfo -flags 11666 jinfo -sysprops 11666
查看打印GC日志参数
jinfo -flag PrintGC 11666 jinfo -flag PrintGCDetails 11666
打开GC日志参数
jinfo -flag +PrintGC 11666 jinfo -flag +PrintGCDetails 11666
关闭GC日志参数
jinfo -flag -PrintGC 11666 jinfo -flag -PrintGCDetails 11666
还可使用下面的命令查看那些参数可使用jinfo命令来管理:
java -XX:+PrintFlagsFinal -version | grep manageable
经常使用JVM参数:
-Xms:初始堆大小,默认为物理内存的1/64(<1GB);默认(MinHeapFreeRatio参数能够调整)空余堆内存小于40%时,JVM就会增大堆直到-Xmx的最大限制
-Xmx:最大堆大小,默认(MaxHeapFreeRatio参数能够调整)空余堆内存大于70%时,JVM会减小堆直到 -Xms的最小限制
-Xmn:新生代的内存空间大小,注意:此处的大小是(eden+ 2 survivor space)。与jmap -heap中显示的New gen是不一样的。整个堆大小=新生代大小 + 老生代大小 + 永久代大小。
在保证堆大小不变的状况下,增大新生代后,将会减少老生代大小。此值对系统性能影响较大,Sun官方推荐配置为整个堆的3/8。
-XX:SurvivorRatio:新生代中Eden区域与Survivor区域的容量比值,默认值为8。两个Survivor区与一个Eden区的比值为2:8,一个Survivor区占整个年轻代的1/10。
-Xss:每一个线程的堆栈大小。JDK5.0之后每一个线程堆栈大小为1M,之前每一个线程堆栈大小为256K。应根据应用的线程所需内存大小进行适当调整。在相同物理内存下,
减少这个值能生成更多的线程。可是操做系统对一个进程内的线程数仍是有限制的,不能无限生成,经验值在3000~5000左右。通常小的应用, 若是栈不是很深, 应该是128k够用的,
大的应用建议使用256k。这个选项对性能影响比较大,须要严格的测试。和threadstacksize选项解释很相似,官方文档彷佛没有解释,
在论坛中有这样一句话:"-Xss
is
translated
in
a VM flag named ThreadStackSize”通常设置这个值就能够了。
-XX:PermSize:设置永久代(perm gen)初始值。默认值为物理内存的1/64。
-XX:MaxPermSize:设置持久代最大值。物理内存的1/4。
jstat命令是使用频率比较高的命令,主要用来查看JVM运行时的状态信息,包括内存状态、垃圾回收等。
命令格式:
jstat [option] LVMID [interval] [count]
其中LVMID是进程id,interval是打印间隔时间(毫秒),count是打印次数(默认一直打印)
option参数解释:
经常使用示例及打印字段解释:
jstat -gcutil 11666 1000 3
11666为pid,每隔1000毫秒打印一次,打印3次
输出:
S0 S1 E O M CCS YGC YGCT FGC FGCT GCT
6.17 0.00 6.39 33.72 93.42 90.57 976 57.014 68 53.153 110.168
6.17 0.00 6.39 33.72 93.42 90.57 976 57.014 68 53.153 110.168
6.17 0.00 6.39 33.72 93.42 90.57 976 57.014 68 53.153 110.168
字段解释:
jstat -gc 11666 1000 3
-gc和-gcutil参数相似,只不过输出字段不是百分比,而是实际的值。
输出:
S0C S1C S0U S1U EC EU OC OU MC MU CCSC CCSU YGC YGCT FGC FGCT GCT
25600.0 25600.0 0.0 1450.0 204800.0 97460.7 512000.0 172668.8 345736.0 322997.7 48812.0 44209.0 977 57.040 68 53.153 110.193
25600.0 25600.0 0.0 1450.0 204800.0 97460.7 512000.0 172668.8 345736.0 322997.7 48812.0 44209.0 977 57.040 68 53.153 110.193
25600.0 25600.0 0.0 1450.0 204800.0 97460.7 512000.0 172668.8 345736.0 322997.7 48812.0 44209.0 977 57.040 68 53.153 110.193
字段解释:
jstack是用来查看JVM线程快照的命令,线程快照是当前JVM线程正在执行的方法堆栈集合。使用jstack命令能够定位线程出现长时间卡顿的缘由,例如死锁,死循环等。jstack还能够查看程序崩溃时生成的core文件中的stack信息。
命令格式:
jstack [-l] <pid> (链接运行中的进程)
jstack -F [-m] [-l] <pid> (链接挂起的进程)
jstack [-m] [-l] <executable> <core> (链接core文件)
jstack [-m] [-l] [server_id@]<remote server IP or hostname> (链接远程debug服务器)
option参数解释:
经常使用示例:
jstack -l 11666 | more
输出信息:
Full thread dump Java HotSpot(TM) 64-Bit Server VM (25.25-b02 mixed mode): "Attach Listener" #25525 daemon prio=9 os_prio=0 tid=0x00007fd374002000 nid=0x70e8 waiting on condition [0x0000000000000000] java.lang.Thread.State: RUNNABLE Locked ownable synchronizers: - None ......
具体的输出解释比较多,后续会有一篇博客来解释。如今想要学习的话请参考这篇博客。
jmap是用来生成堆dump文件和查看堆相关的各种信息的命令,例如查看finalize执行队列,heap的详细信息和使用状况。
命令格式:
jmap [option] <pid> (链接正在执行的进程)
jmap [option] <executable <core> (链接一个core文件)
jmap [option] [server_id@]<remote server IP or hostname> (连接远程服务器)
option参数解释:
dump-options:
live 只转储存活的对象,若是没有指定则转储全部对象
format=b 二进制格式
file=<file> 转储文件到 <file>
经常使用示例:
jmap -dump:live,format=b,file=dump.hprof 11666
输出:
Dumping heap to /dump.hprof ... Heap dump file created
这个命令是要把java堆中的存活对象信息转储到dump.hprof文件
jmap -finalizerinfo 11666
输出:
Attaching to process ID 11666, please wait... Debugger attached successfully. Server compiler detected. JVM version is 24.71-b01 Number of objects pending for finalization: 0
输出结果的含义为当前没有在等待执行finalizer方法的对象
jmap -heap 11666
输出堆的详细信息
输出:
Attaching to process ID 11666, please wait... Debugger attached successfully. Server compiler detected. JVM version is 25.25-b02 using thread-local object allocation. Parallel GC with 4 thread(s) Heap Configuration: //堆内存初始化配置 MinHeapFreeRatio = 0 //对应jvm启动参数-XX:MinHeapFreeRatio设置JVM堆最小空闲比率(default 40) MaxHeapFreeRatio = 100 //对应jvm启动参数 -XX:MaxHeapFreeRatio设置JVM堆最大空闲比率(default 70) MaxHeapSize = 1073741824 (1024.0MB) //对应jvm启动参数-XX:MaxHeapSize=设置JVM堆的最大大小 NewSize = 22020096 (21.0MB) //对应jvm启动参数-XX:NewSize=设置JVM堆的新生代的默认大小 MaxNewSize = 357564416 (341.0MB) //对应jvm启动参数-XX:MaxNewSize=设置JVM堆的新生代的最大大小 OldSize = 45088768 (43.0MB) //对应jvm启动参数-XX:OldSize=<value>:设置JVM堆的老年代的大小 NewRatio = 2 //对应jvm启动参数-XX:NewRatio=:新生代和老生代的大小比率 SurvivorRatio = 8 //对应jvm启动参数-XX:SurvivorRatio=设置新生代中Eden区与Survivor区的大小比值 MetaspaceSize = 21807104 (20.796875MB) // 元数据区大小 CompressedClassSpaceSize = 1073741824 (1024.0MB) //类压缩空间大小 MaxMetaspaceSize = 17592186044415 MB //元数据区最大大小 G1HeapRegionSize = 0 (0.0MB) //G1垃圾收集器每一个Region大小 Heap Usage: //堆内存使用状况 PS Young Generation Eden Space: //Eden区内存分布 capacity = 17825792 (17.0MB) //Eden区总容量 used = 12704088 (12.115562438964844MB) //Eden区已使用 free = 5121704 (4.884437561035156MB) //Eden区剩余容量 71.26801434685203% used //Eden区使用比率 From Space: //其中一个Survivor区的内存分布 capacity = 2097152 (2.0MB) used = 1703936 (1.625MB) free = 393216 (0.375MB) 81.25% used To Space: //另外一个Survivor区的内存分布 capacity = 2097152 (2.0MB) used = 0 (0.0MB) free = 2097152 (2.0MB) 0.0% used PS Old Generation capacity = 52428800 (50.0MB) //老年代容量 used = 28325712 (27.013504028320312MB) //老年代已使用 free = 24103088 (22.986495971679688MB) //老年代空闲 54.027008056640625% used //老年代使用比率 15884 interned Strings occupying 2075304 bytes.
jmap -histo:live 11666 | more
输出存活对象统计信息
输出:
num #instances #bytes class name ---------------------------------------------- 1: 46608 1111232 java.lang.String 2: 6919 734516 java.lang.Class 3: 4787 536164 java.net.SocksSocketImpl 4: 15935 497100 java.util.concurrent.ConcurrentHashMap$Node 5: 28561 436016 java.lang.Object
jhat是用来分析jmap生成dump文件的命令,jhat内置了应用服务器,能够经过网页查看dump文件分析结果,jhat通常是用在离线分析上。
命令格式:
jhat [option] [dumpfile]
option参数解释:
0: 无debug输出
1: Debug hprof file parsing
2: Debug hprof file parsing, no server
经常使用示例:
jhat dump.hprof
除了以上所述的经常使用命令行工具以外还有图形化工具,使用上比较简单。在命令行下执行jconsole和jvisualvm便可。具体的用法,本身去点一点就了解了。
jconsole:
jvisualvm: