java虚拟机的一些常用的命令
实际上,在下载的JDK的包中也有一些可以用于监视虚拟机运行状态和进行故障处理的工具,如下图所示。
下面主要介绍几个常用的java常用的工具
jps (JVM Process Status Tool)
jps, JVM进程状态的工具,与ps类似,这个功能主要用于列出正在运行的虚拟机的进程。并显示虚拟机执行的主类(main() 所在的类)的名称以及这些进程本地虚拟机中唯一的id(LVMID, Local Virtual Machine Identifier)。
jps命令格式:
jps [option] [hostId]
jsp的option参数:
选项 | 作用 |
---|---|
-q | 只输出LVMID,省略主类的名称 |
-m | 输出虚拟机进程启动时传递給主类main()函数的参数 |
-l | 输出主类的全名,如果进程执行的是JAR包,则输出JAR路径 |
-v | 输出虚拟机进程启动时的JVM参数 |
如图首先运行一次jps,然后对MethodMain的程序执行一次debug,再次查看。
jstat (JVM Statistics Monitoring Tool)
jstat, 虚拟机统计信息监视工具,用于监视虚拟机各种运行状态的工具。它可
以显示本地或者远程虚拟机进程中的类加载、内存、垃圾收集、即时编译等运行时数据,在没有GUI图形界面、只提供了纯文本控制台环境的服务器上,它将是运行期定位虚拟机性能问题的常用工具。
jstat的命令格式
jstat [option vmid [interval[s|ms] [count]]]
对于命令格式中的VMID与LVMID需要特别说明一下:如果是本地虚拟机进程,VMID与LVM ID 是一致的;如果是远程虚拟机进程,那VMID的格式应当是:
[protocol:][//]lvmid[@hostname[:port]/servername]
jstat的option参数:
选项 | 作用 |
---|---|
-class | 监视类加载,卸载数量,总空间以及类装载所耗费的时间 |
-gc | 监视java堆状况,包括Eden区,2个survivor区,老年代,永久代等的容量,已用空间,垃圾收集时间合计等信息 |
-gccapacity | 监视内容与-gc基本相同,但输出主要关注java堆各个区域使用到的最大,最小空间 |
-gcutil | 监视内容与-gc基本相同,但输出主要关注已使用的空间占总空间的百分比 |
-gccause | 与-gcutil功能一样,但是会额外输出导致上一次垃圾收集产生的原因 |
-gcnew | 监视新生代垃圾收集状况 |
-gcnewcapacity | 监视内容与-gcnew基本相同,输出主要关注使用到的最大,最小空间 |
-gcold | 监视老年代垃圾收集状况 |
-gcoldcapacity | 监视内容与-gcold基本相同,输出主要关注使用到的最大,最小空间 |
-gcpermcapacity | 监视永久代使用到的最大,最小空间 |
-compiler | 输出即时编译器编译过的方法,耗时等信息 |
-printcompilation | 输出已被即时编译的方法 |
-gc | 监视java堆状况,包括Eden区,2个survivor区,老年代,永久代等的容量,已用空间,垃圾收集时间合计等信息 |
-gccapacity | 监视内容与-gc基本相同,但输出主要关注java堆各个区域使用到的最大,最小空间 |
-gcutil | 监视内容与-gc基本相同,但输出主要关注已使用的空间占总空间的百分比 |
-gccause | 与-gcutil功能一样,但是会额外输出导致上一次垃圾收集产生的原因 |
-gcnew | 监视新生代垃圾收集状况 |
-gcnewcapacity | 监视内容与-gcnew基本相同,输出主要关注使用到的最大,最小空间 |
-gcold | 监视老年代垃圾收集状况 |
-gcoldcapacity | 监视内容与-gcold基本相同,输出主要关注使用到的最大,最小空间 |
-gcpermcapacity | 监视永久代使用到的最大,最小空间 |
-compiler | 输出即时编译器编译过的方法,耗时等信息 |
-printcompilation | 输出已被即时编译的方法 |
如图,survivor0,survivor1(s0,s1)占比0%;Eden区域占比12.02%;老年代(old)区域占比0%.;元数据区域(M)使用比例17.65%; 压缩比例(CCS) 比例为19.90%; 年轻代GC次数(YGC)为0;年轻代GC(YCGCT)总耗时为0; 发生Full GC(FGC)次数为0;发生Full GC Time(FGCT)时间为0;所有GC(GCT)的时长为0.
jinfo (Configuration Info for Java)
jinfo,Java配置信息工具用于实时查看和调整虚拟机各项参数。
jinfo的命令格式:
jinfo [ option ] pid
jinfo option:
待补充执行的命令:
jmap(Memory Map for Java)
jmap,Java内存映像工具用于生成内存转存快照。jmap 的作用并不仅仅是为了获取堆转储快照,它还可以查询finaliz e执行队列、Java堆和方法区的 详细信息,如空间使用率、当前用的是哪种收集器等。
jmap 命令格式:
jmap [ option ] vmid
选项 | 作用 |
---|---|
-dump | 生成dump快照 |
-finalizerinfo | 显示在F-Queue中等待Finalizer线程中执行finalize方法的对象。 |
-heap | 显示java堆详细信息,如使用那种回收器,参数配置,分代状况等 |
-histo | 显示堆中对象统计信息,包括类,实例数量,合计容量 |
-permstat | 以ClassLoader为统计口径显示永久代内存状态。 |
-F | 当虚拟机进程堆-dump选项没有响应是,可使用这个选项强制生成dump快照。 |
那么生成的dump怎么使用呢?
在java工具包中,有一个jhat,在分析完毕后,可以在http://localhost:7000/上展示当前的快照。
jhat:虚拟机堆转储快照分析工具
JDK提供jhat(JVM Heap Analysis Tool)命令与jmap搭配使用,来分析jmap生成的堆转储快照。 jhat内置了一个微型的HTTP/Web服务器,生成堆转储快照的分析结果后,可以在浏览器中查看。不过 实事求是地说,在实际工作中,除非手上真的没有别的工具可用,否则多数人是不会直接使用jhat命令 来分析堆转储快照文件的,主要原因有两个方面。一是一般不会在部署应用程序的服务器上直接分析堆转储快照,即使可以这样做,也会尽量将堆转储快照文件复制到其他机器上进行分析,因为分析工作是一个耗时而且极为耗费硬件资源的过程,既然都要在其他机器上进行,就没有必要再受命令行工具的限制了。
jstack(Stack Trace for Java)
jstack:Java堆栈跟踪工具,命令用于生成虚拟机当前时刻的线程快照。线程快照就是当前虚拟机内每一条线程正在执行的方法堆栈的集合,生成线程快照的 目的通常是定位线程出现长时间停顿的原因,如线程间死锁、死循环、请求外部资源导致的长时间挂 起等,都是导致线程长时间停顿的常见原因。线程出现停顿时通过jstack来查看各个线程的调用堆栈, 就可以获知没有响应的线程到底在后台做些什么事情或者等待着什么资源。
jstack 命令格式
jstack [ option ] vmid
jstack的option选项
选项 | 作用 |
---|---|
-F | 当正常输出的请求不被响应时,强制输出线程堆栈 |
-l | 除了栈外,显示关于锁的附加信息 |
-m | 如果调用了本地方法的话,可以显示C/C++的堆栈 |