jvm 命令

jps

   jps主要用来输出JVM中运行的进程状态信息。语法格式如下:

jps [options] [hostid] 如果不指定hostid就默认为当前主机或服务器。
-q 不输出类名、Jar名和传入main方法的参数
-m 输出传入main方法的参数
-l 输出main类或Jar的全限名
-v 输出传入JVM的参数

  例子

jinfo

    可以输出并修改运行时的java 进程的opts。用处比较简单,就是能输出并修改运行时的java进程的运行参数。用法是jinfo pid

jstack

  jstack主要用来查看某个Java进程内的线程堆栈信息。语法格式如下:jstack pid

jstack [option] pid

-l long listings,会打印出额外的锁信息,在发生死锁时可以用jstack -l pid来观察锁持有情况
-m mixed mode,不仅会输出Java堆栈信息,还会输出C/C++堆栈信息(比如Native方法)

  jstack可以定位到线程堆栈,根据堆栈信息我们可以定位到具体代码,所以它在JVM性能调优中使用得非常多

jstat

  jstat(JVM统计监测工具)。语法格式如下

jstat [ generalOption | outputOptions vmid [interval[s|ms] [count]] ]

vmid是虚拟机ID,在Linux/Unix系统上一般就是进程ID。interval是采样时间间隔。count是采样数目。比如下面输出的是GC信息,采样时间间隔为250ms,采样数为4:

要明白上面各列的意义,先看JVM堆内存布局:

可以看出:

堆内存 = 年轻代 + 年老代 + 永久代
年轻代 = Eden区 + 两个Survivor区(From和To)
S0C、S1C、S0U、S1U:Survivor 0/1区容量(Capacity)和使用量(Used)
EC、EU:Eden区容量和使用量
OC、OU:年老代容量和使用量
PC、PU:永久代容量和使用量
YGC、YGT:年轻代GC次数和GC耗时
FGC、FGCT:Full GC次数和Full GC耗时
GCT:GC总耗时

jmap

jmap用来查看堆内存使用状况。 语法格式如下:

jmap [option] pidjmap -permstat pid  打印进程的类加载器和类加载器加载的持久代对象信息,输出:类加载器名称、对象是否存活(不可靠)、对象地址、父类加载器、已加载的类大小等信息jmap -heap pid   查看进程堆内存使用情况,包括使用的GC算法、堆配置参数和各代中堆内存使用情况jmap -histo[:live] pid  查看堆内存中的对象数目、大小统计直方图,如果带上live则只统计活对象

例子

下面我们来一个实例找出某个Java进程中最耗费CPU的Java线程并定位堆栈信息,用到的命令有ps、top、printf、jstack、grep。

找出该进程内最耗费CPU的线程,可以使用ps -Lfp pid或者ps -mp pid -o THREAD, tid, time或者top -Hp pid,我这里用第三个,输出如下:

TIME列就是各个Java线程耗费的CPU时间,CPU时间最长的是线程ID为12811的线程,用

printf "%x\n" 12811

得到12811的十六进制值为320b,下面会用到。

OK,下一步终于轮到jstack上场了,它用来输出进程12811的堆栈信息,然后根据线程ID的十六进制值grep,如下:

jstack 12809 |  grep ‘320‘ -C20

-A 之后多少行-B 之前多少行-C 上下多少行
时间: 2024-10-28 10:59:16

jvm 命令的相关文章

六、JVM命令和工具

当我们在平常遇到一些内存溢出,或者栈深度的问题的时候,需要查问题出在哪里,就需要用到一些jvm命令. 一.常用的jvm命令有: jps:显示系统所有虚拟机进程信息 jstate:显示虚拟机各方面的运行数据信息,各内存区域的使用情况 jstack:显示虚拟机中线程的快照信息 jmap:生成虚拟机内存转存快照(heapdump) jhat:分析生成的转存快照问题 二.分析工具 比较有用的两个工具: jconsole:虚拟机自带的工具 visual vm:第三方插件

常用的jvm命令

(1)jps -lv 列出所有java进程 第一个参数是pid: 第二个为jvm参数和完整的执行类名 (2)jinfo <pid> 描述:输出给定 java 进程所有的配置信息.包括 java 系统属性和 jvm 命令行标记等. (3)jstack <pid> 为指定的线程输出 java 的线程堆栈信息,包括了进程里的所有线程.每一个线程 frame ,包括类全名,方法名,代码行. (4)jstat -gcutil <pid> <interval> 查看ja

每个Java程序员必须知道的5个JVM命令行标志

本文是Neward & Associates的总裁Ted Neward为developerworks独家撰稿"你不知道5个--"系列中的一篇,JVM是多数开发人员视为理所当然的Java功能和性能背后的重负荷机器.然而,我们很少有人能理解JVM是如何进行工作的-像任务分配和垃圾收集.转动线程.打开和关闭文件.中断和/或JIT编译Java字节码,等等. 不熟悉JVM将不仅会影响应用程序性能,而且当JVM出问题时,尝试修复也会很困难. 本文将介绍一些命令行标志,您可以使用它们来诊断和

5个JVM命令行标志,值得你知道

本文是Neward & Associates的总裁Ted Neward为developerworks独家撰稿“你不知道5个……”系列中的一篇,JVM是多数开发人员视为理所当然的Java功能和性能背后的重负荷机器.然而,我们很少有人能理解JVM是如何进行工作的—像任务分配和垃圾收集.转动线程.打开和关闭文件.中断和/或JIT编译Java字节码,等等. 不熟悉JVM将不仅会影响应用程序性能,而且当JVM出问题时,尝试修复也会很困难. 本文将介绍一些命令行标志,您可以使用它们来诊断和调优您的Java虚

【JVM命令系列】jstack

jstack用于打印出给定的java进程ID或core file或远程调试服务的Java堆栈信息,如果是在64位机器上,需要指定选项"-J-d64",Windows的jstack使用方式只支持以下的这种方式:jstack [-l] pid 如果java程序崩溃生成core文件,jstack工具可以用来获得core文件的java stack和native stack的信息,从而可以轻松地知道java程序是如何崩溃和在程序何处发生问题.另外,jstack工具还可以附属到正在运行的java程

【JVM命令系列】jmap

命令基本概述 Jmap是一个可以输出所有内存中对象的工具,甚至可以将VM 中的heap,以二进制输出成文本.打印出某个java进程(使用pid)内存内的,所有'对象'的情况(如:产生那些对象,及其数量). 使用方法 jmap -histo pid.如果使用SHELL ,可采用jmap -histo pid>a.log日志将其保存到文件中,在一段时间后,使用文本对比工具,可以对比出GC回收了哪些对象.jmap -dump:format=b,file=outfile 3024可以将3024进程的内存

学习-JVM命令

jstat jstat (JVM statistics Monitoring)是用于监视虚拟机运行时状态信息的命令,它可以显示出虚拟机进程中的类装载.内存.垃圾收集.JIT编译等运行数据. 格式:jstat [option] LVMID [interval] [count] 参数: [option] : 操作参数 class : class loader的行为统计 compiler : HotSpt JIT编译器行为统计 gc : 垃圾回收堆的行为统计 gccapacity : 各个垃圾回收代容

Java虚拟机3:常用JVM命令参数

http://www.cnblogs.com/xrq730/p/4830692.html 之后写的东西就会用到虚拟机参数了,现在这里汇个总自己平时用到的.看到的一些虚拟机参数.现在看不懂没关系,反正之后都会用到的: (1)-Xms20M 表示设置堆容量的最小值为20M,必须以M为单位 (2)-Xmx20M 表示设置堆容量的最大值为20M,必须以M为单位.将-Xmx和-Xms设置为一样可以避免堆自动扩展.大的项目-Xmx和-Xms一般都要设置到10G.20G甚至还要高 (3)-verbose:gc

jvm命令基础使用

TOMCAT_ID为tomcat的进程号. 1.查看jvm堆栈信息 /bin/kill -3 TOMCAT_ID:无法输出到单独的文件中,只能在tomcat的启动文件中打印相关的堆栈信息. jstack TOMCAT_ID >> jstack.txt:打印jvm的堆栈信息到单独的文件中. 2.查看jvm的内存dump信息. jmap -dump:format=b,file=/data/jmap.txt TOMCAT_ID