Java虚拟机--经常使用Java命令(一)

1.Java经常使用命令java

  jps:查看本机的Java进程信息。c++

  jstack:打印线程的栈信息,制做线程Dump。浏览器

  jmap:打印内存映射,只作堆Dump。框架

  jstat:性能监控工具。工具

  jhat:内存分析工具。性能

  jconsole:简易的可视化控制台。学习

  jvisualvm:功能强大的控制台。spa

2.什么是Java Dump?有什么用?命令行

  Java Dump就是虚拟机的运行时快照,其将Java虚拟机运行时的状态和信息保存到文件中去。做用:能够了解程序运行时,虚拟机中的运行时状态信息;针对非业务逻辑性的BUG,如内存泄漏、内存溢出等。线程

3.制做Java Dump

  ■ 使用Java虚拟机制做Dump

    -xx:+HeapDumpOnOutOfMemoryError     指示虚拟机在发生内存不足错误时,自动生成堆Dump。

  ■ 使用图形工具制做Dump

    使用JDK 1.6 自带的工具:Java VisualVM

  ■ 使用命令行制做Dump

    jstack:制做线程Dump 

    jmap:制做堆Dump

4.经常使用命令之jps

  做用

  显示当前全部Java进程pid的命令。

  使用

  想要学习一个命令,先来看看帮助,使用jps -help查看帮助:

  

  -q 只显示pid,不显示class名称,jar文件名和传递给main 方法的参数

  

  -l 输出应用程序main class的完整package名 或者 应用程序的jar文件完整路径名

  

  -v 输出传递给JVM的参数

  

5.经常使用命令之javap

  javap是jdk自带的一个工具,能够对代码反编译,也能够查看java编译器生成的字节码。

  javap命令分解一个class文件,它根据options来决定到底输出什么。若是没有使用options,那么javap将会输出包,类里的protected和public域以及类里的全部方法。javap将会把它们输出在标准输出上。来看这个例子,先编译(javac)下面这个类。

  

  在命令行上键入javap DocFooter后

  

  若是加入了-c,即javap -c DocFooter,输出的字节码以下:

  

  javap能够用于反编译和查看编译器编译后的字节码。用java -c比较多;该命令用于列出每一个方法所执行的JVM指令,并显示每一个方法的字节码的实际做用。

6.经常使用命令之jstack

  jstack是JDK自带的一种堆栈跟踪工具。

  jstack用于生成java虚拟机当前时刻的线程快照。线程快照是当前java虚拟机内每一条线程执行的方法堆栈的集合,生成线程快照的主要目的是定位线程长时间停顿的缘由,如线程间死锁、死循环等。线程出现停顿的时候经过jstack来查看各个线程的调用堆栈,就能够知道没有响应的线程到底在后台作什么。若是java程序崩溃,生成core文件,jstack工具能够用来得到core文件的java stack和native stack的信息,从而能够轻松的知道java程序是如何崩溃和在程序何处发出问题。

  让咱们先jstack -help

  

  -l 长列表,打印关于锁的附加信息;-F 当-l没有响应时强制打印栈信息;-m 打印javanative/c/c++框架的全部栈信息;pid用jps查询。接下来让咱们来探讨一下死锁问题:什么是死锁呢?打个比方:AB两人去靶场打靶,就一把枪,A拿着子弹,B拿着枪,就这样A须要B手中的枪才能打靶,一样B须要A手中的子弹才能打靶,而后他俩大眼瞪小眼,谁也不说话,谁也不放下手中的东西,而后一眼万年。。。这在程序中表现为两把锁,当发现死锁问题时,用jstack是能够观察到的如图:

  

  上面的信息,明确的告诉了咱们什么地方,哪条线程出现了死锁。这样咱们就能够进行定位,而后解决了。

  备注:虚拟机执行FULL GC时,会阻塞全部的用户线程,所以得到同步所的线程也可能被阻塞。查看线程Dump时,首先要看内存使用状况。

7.经常使用命令之jmap

  jmap主要用于打印指定Java进程的共享内存映射或堆内存细节,能够用jmap生成堆Dump。

  什么是堆Dump?

  是反映内存使用状况的内存镜像,其中主要包括系统信息虚拟机属性完整的线程Dump全部类对象的状态等。通常在GC异常、内存不足的状况下,咱们怀疑又内存泄漏,这时候咱们就能够制做Heap Dump来查看状况,分析缘由。

  首先jmap后,会出现-help的信息:

  

  

  

  查看内存使用状况,用jmap -heap pid:

  

  产看堆内存(histogram)中的对象数量及大小,用jmap -histo  pid:(用histo:live时,会先触发gc,而后统计信息)

  

  将内存使用状况输出到文件,执行的命令是:jmap  -dump:fomat=b,file=heapDump  pid,而后用jhat命令能够参看:jhat -port 5000 heapDump,而后在浏览器中访问:http:localhost:5000/产看信息:

   

  

  备注:

  ■ 若是程序内存不足或频繁GC时,极可能存在内存泄漏的状况,此时就能够借助Java堆Dump查看对象的状况。

  ■ 制做heap Dump 能够用jamp命令

  ■ 能够先用jmap -heap查看内存的使用状况

  ■ 使用jamp -histo:[live] 查看堆内存的使用状况,若是大量对象在持续被引用,并无释放掉,则产生了内存泄漏,就要结合代码,把不用的对象释放掉。

  ■ 也能够用jmap -dump:format=b,file=<fileName> pid 将堆信息保存到文件中,而后用jhat产看。

  ■ 若是出现内存泄漏等状况,建议多Dump几回。

    参考资料http://www.hollischuang.com/archives/308

相关文章
相关标签/搜索