1.Java常用命令

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

  jstack:打印线程的栈信息,制作线程Dump。

  jmap:打印内存映射,只做堆Dump。

  jstat:性能监控工具。

  jhat:内存分析工具。

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

  jvisualvm:功能强大的控制台。

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查看帮助:

  

java 虚拟机锁 java虚拟机指令_java 虚拟机锁

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

  

java 虚拟机锁 java虚拟机指令_Java_02

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

  

java 虚拟机锁 java虚拟机指令_java 虚拟机锁_03

  -v 输出传递给JVM的参数

  

java 虚拟机锁 java虚拟机指令_java 虚拟机锁_04

5.常用命令之javap

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

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

  

java 虚拟机锁 java虚拟机指令_java_05

  在命令行上键入javap TestJavap后

  

java 虚拟机锁 java虚拟机指令_java 虚拟机锁_06

  如果加入了-c,即javap -c TestJavap,输出的字节码如下:

  

java 虚拟机锁 java虚拟机指令_常用命令_07

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

6.常用命令之jstack

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

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

  让我们先jstack -help

  

java 虚拟机锁 java虚拟机指令_java 虚拟机锁_08

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

  

java 虚拟机锁 java虚拟机指令_java_09

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

  备注:虚拟机执行FULL GC时,会阻塞所有的用户线程,因此获得同步所的线程也可能被阻塞。查看线程Dump时,首先要看内存使用情况。

7.常用命令之jmap

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

  什么是堆Dump?

  是反映内存使用情况的内存镜像,其中主要包括系统信息、虚拟机属性、完整的线程Dump、所有类和对象的状态等。一般在GC异常、内存不足的情况下,我们怀疑又内存泄漏,这时候我们就可以制作Heap Dump来查看情况,分析原因。

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

  

java 虚拟机锁 java虚拟机指令_java_10

  

java 虚拟机锁 java虚拟机指令_java_11

  

java 虚拟机锁 java虚拟机指令_java_12

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




java 虚拟机锁 java虚拟机指令_常用命令_13


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



  

java 虚拟机锁 java虚拟机指令_Java_14


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

  

java 虚拟机锁 java虚拟机指令_常用命令_15

8.常用命令之jstat

Heap size垃圾回收状况的监控.

  

  jstat命令格式:

  

java 虚拟机锁 java虚拟机指令_java 虚拟机锁_16


  参数含义

  option:选项,我们一般使用-gc查看gc情况

  vmid:VM的进程号,即当前运行的Java进程号

  interval:间隔时间,单位为秒或毫秒

  count:打印次数,如果缺省则打印无数次

  :interval和count代表查询间隔和打印次数,若省略这两个参数,则只查询一次。假设需要每200毫秒查询一次当前Java进程垃圾收集情况,一共查询5次,则:

  

java 虚拟机锁 java虚拟机指令_常用命令_17


  option  代表着用户希望查询的虚拟机信息,主要分为3类:类装载垃圾收集运行期编译状况,具体选项和作用如下:

  

java 虚拟机锁 java虚拟机指令_java_18


  常见组合:

  

  jstat -class pid:显示加载class的数量及所占空间等信息.其中:loaded表示类加载的数量;bytes表示类加载的字节数;unloaded表示卸载类的数量;time表示装载类和卸载类所用的时间.

  jstat -compiler pid:显示VM实时编译的数量等信息.其中:compiled表示编译任务执行数量;failed表示编译失败次数;invalid表示编译任务失效次数;time表示编译任务消耗的时间;failedType表示最后一个编译失败任务的类型;failedMethod表示最后一个编译失败任务所在的类及方法.

  jstat -gc pid:显示gc信息,查看次数及时间.其中:s0c表示年轻代第一个survivor(幸存区)容量;s1c表示年轻代第二个survivor容量;s0u表示第一个survivor已使用空间;ec表示Eden容量;eu表示Eden已使用空间;oc表示老年代容量;mc表示持久代容量;YGC表示程序启动到采样时年轻代中的gc次数;YGCT表示所用时间;FGC表示老年代gc次数;GCT表示gc的总时间.

  jstat -gccapacity pid:可以显示在VM内存中三代对象的使用和占用大小.其中:NGCMN表示年轻代中初始化(最小)的大小;NGCMX表示初始化(最大)的大小;NGC表示年轻代中容量;

  jstat -gcutil pid:统计gc信息.s0表示第一个survivor占用百分比;s1表示第二个占用百分比;E表示Eden占用百分比;O表示老年占用百分比;M表示持久代占用百分比.

9.常用命令之jhat

  jhat全名为Java Heap Analysis Tool,即是一个用来分析Java堆情况的命令.如用jmap生成Dump文件,然后用jhat查看.

  

  导出Dump:

  先生成Dump文件:jmap -dump:format=b,file=fileName pid

  然后解析Java堆转储文件,并启动一个web server:jhat fileName 会启动一个端口,用localhost+端口号访问.

  

java 虚拟机锁 java虚拟机指令_Java_19


  

java 虚拟机锁 java虚拟机指令_Java_20


  

  备注

  ■ 如果程序内存不足或频繁GC时,很可能存在内存泄漏的情况,此时就可以借助Java堆Dump查看对象的情况。

  ■ 制作heap Dump 可以用jamp命令

  ■ 可以先用jmap -heap查看内存的使用情况

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

  ■ 也可以用jmap -dump:format=b,file= pid 将堆信息保存到文件中,然后用jhat产看。

  ■ 如果出现内存泄漏等情况,建议多Dump几次。