现实企业级Java开发中,有时候我们会碰到下面这些问题:
OutOfMmoryError,内存不足
内存泄露
线程死锁
锁争用(LockContntion)
Java进程消耗CPU过高
......
这些问题在日常开发中可能被很多人忽视(比如有的人遇到上面的问题只是重启服务器或者调大内存,而不会深究问题根源),但能够理解并解决这些问题是Java程序员进阶的必备要求。本文将对一些常用的JVM性能调优监控工具进行介绍,希望能起抛砖引玉之用。本文参考了网上很多资料,难以一一列举,在此对这些资料的作者表示感谢!
A、jps(JavaVirtualMachinProcssStatusTool)
jps主要用来输出JVM中运行的进程状态信息。语法格式如下:
1
jps[options][hostid]
如果不指定hostid就默认为当前主机或服务器。
命令行参数选项说明如下:
1
2
3
4
-q不输出类名、Jar名和传入main方法的参数
-m输出传入main方法的参数
-l输出main类或Jar的全限名
-v输出传入JVM的参数
比如下面:
1
2
3
4
5
6
7
8
root
ubuntu:/#jps-m-lorg.artifactory.standalon.main.Main/usr/local/artifactory-2.2.5/tc/jtty.xml