jvm监控工具jps,jstat,jstack,jmap的使用方法

在平常运维分析jvm的时候通常用到的工具的jps,jstat,jstack,jmap用于分析tomcat遇到的各种问题

tomcat常见的问题有:

OOM,线程死锁(lock dead),锁争用(lock contention),Java消耗过多的CPU

可以通过以上工具进行分析

生产常用分析方法快速入口:

#jps        --> 查看运行的java进程

#jstat -gc 进程pid --> 查看进程新生代老年代的内存使用情况,年轻代老年代垃圾收集次数及时间

#jstat -gccause 进程pid --> 查看进程垃圾收集原因

#jmap -heap 进程pid --> 查看进程堆内存具体使用情况

#jstack -l 进程pid --> 查看线程信息,用于分析线程争取,死锁造成tomcat假死的情况

jps:java虚拟机进程查看工具

jps [options] [hostid]

-m:输出传入main方法的参数

-l:显示main的完整类名

-v:显示为jvm虚拟机指定的参数

常用的组合:

#jps -m -l

#jps -m -l -v

[[email protected] bin]$ jps -m -l -v
5966 org.apache.catalina.startup.Bootstrap start -Djava.util.logging.config.file=/mnt/tomcat/conf/logging.properties -Djava.util.logging.manager=org.apache.juli.ClassLoaderLogManager -Djava.endorsed.dirs=/mnt/tomcat/endorsed -Dcatalina.base=/mnt/tomcat -Dcatalina.home=/mnt/tomcat -Djava.io.tmpdir=/mnt/tomcat/temp
7006 sun.tools.jps.Jps -m -l -v -Denv.class.path=.:/usr/java/jdk1.7.0_79/lib/dt.jar:/usr/java/jdk1.7.0_79/lib/tools.jar -Dapplication.home=/usr/java/jdk1.7.0_79 -Xms8m

jstat:jvm虚拟机运行时内存使用及垃圾回收情况监控

jstat -<option> pid:(<options>为必须选项)

-options:查看有哪些选项可以使用

-gc:使用此选项时,后面加java的进程号;例jstat -gc 27564 [1s](也可跟上多少时间显示一次)

S0C,S1C:表示第一个和第二个生存区的容量
     S0U,S1U:表示第一个和第二个生存区的已使用的容量
     EC,EU:表示eden区域的容量和已用量
     OC,OU:表示老年代区的容量和已用量
     PC,PU:表示持久代的内存容量和已用量
     YGC,YGT:表示新生代的GC发生的次数和耗时
     FGCT,FGCT:表示老年代Full GC发生的次数和耗时
     GCT:表示总的GC耗时

-gccause:
    LGCC:上次GC的原因
    GCC:当前GC的原因

[[email protected] bin]$ jstat -gc 5966
 S0C    S1C    S0U    S1U      EC       EU        OC         OU       PC     PU    YGC     YGCT    FGC    FGCT     GCT   
40960.0 36864.0  0.0   36850.3 253952.0 161159.5  109056.0   74574.4   53248.0 45852.6     19    1.672   3      2.193    3.865
[[email protected] bin]$ jstat -gccause 5966
  S0     S1     E      O      P     YGC     YGCT    FGC    FGCT     GCT    LGCC                 GCC                 
  0.00  99.96  63.76  68.38  86.11     19    1.672     3    2.193    3.865 Allocation Failure   No GC

jmap:查看堆内存使用情况,跟jstat有点类似

-heap:详细的输出堆内存的使用情况
  -histo[:live]:详细显示出整个java堆内存中的对象数目,大小统计结果;
  -histo:显示所有的对象信息
  -histo:live:仅显示存活的对象信息
  -h:获取帮助信息
   例:jmap -heap 5966   --> 查看堆内存的详细使用情况

[[email protected] bin]$ jmap -heap 5966
Attaching to process ID 5966, please wait...
Debugger attached successfully.
Server compiler detected.
JVM version is 24.79-b02

using thread-local object allocation.
Parallel GC with 2 thread(s)

Heap Configuration:
   MinHeapFreeRatio = 0
   MaxHeapFreeRatio = 100
   MaxHeapSize      = 1019215872 (972.0MB)
   NewSize          = 1310720 (1.25MB)
   MaxNewSize       = 17592186044415 MB
   OldSize          = 5439488 (5.1875MB)
   NewRatio         = 2
   SurvivorRatio    = 8
   PermSize         = 21757952 (20.75MB)
   MaxPermSize      = 85983232 (82.0MB)
   G1HeapRegionSize = 0 (0.0MB)
......

jstack:查看某个java进程内的线程堆栈信息

jstack [options] pid
  -l:long listings(会输出完整的锁信息);jstack -l 进程号
  -m:混合模式,即会输出java堆栈及C/C++堆栈信息

通过jstack可以查看线程争用,线程死锁等信息

时间: 2024-11-03 21:27:53

jvm监控工具jps,jstat,jstack,jmap的使用方法的相关文章

JVM调优工具的使用(jps,jstat,jstack,jmap,jhat)

JDK本身提供了很丰富的性能监控工具,除了集成式的visualVM和jConsole外,还有jstat,jstack,jps,jmap,jhat小工具,这些都是性能调优的常用工具 我们在Java的开发中,常常会遇到下面这些问题: 1内存不足,2内存泄漏,3锁争用,4线程锁死,5java进程消耗CPU过高等 这些问题出现的时候 大家常常通过重启服务器或者调大内存来临时解决 一,jps命令 jps主要用来输出JVM中运行的进程状态信息 命令行参数选项: -q 不输出类名.Jar名和传入main方法的

JVM性能调优监控工具jps、jstack、jmap、jhat、jstat使用详解

JDK本身提供了很多方便的JVM性能调优监控工具,除了集成式的VisualVM和jConsole外,还有jps.jstack.jmap.jhat.jstat等小巧的工具,本博客希望能起抛砖引玉之用,让大家能开始对JVM性能调优的常用工具有所了解. 现实企业级Java开发中,有时候我们会碰到下面这些问题: OutOfMemoryError,内存不足 内存泄露 线程死锁 锁争用(Lock Contention) Java进程消耗CPU过高 ...... 这些问题在日常开发中可能被很多人忽视(比如有的

JVM性能调优监控工具jps、jstack、jmap、jhat、jstat使用详解(转VIII)

JDK本身提供了很多方便的JVM性能调优监控工具,除了集成式的VisualVM和jConsole外,还有jps.jstack.jmap.jhat.jstat等小巧的工具,本博客希望能起抛砖引玉之用,让大家能开始对JVM性能调优的常用工具有所了解. 现实企业级Java开发中,有时候我们会碰到下面这些问题: OutOfMemoryError,内存不足 内存泄露 线程死锁 锁争用(Lock Contention) Java进程消耗CPU过高 ...... 这些问题在日常开发中可能被很多人忽视(比如有的

JVM性能调优监控工具jps、jstack、jmap、jhat、jstat、hprof使用详解

现实企业级Java开发中,有时候我们会碰到下面这些问题: OutOfMemoryError,内存不足 内存泄露 线程死锁 锁争用(Lock Contention) Java进程消耗CPU过高 ...... 这些问题在日常开发中可能被很多人忽视(比如有的人遇到上面的问题只是重启服务器或者调大内存,而不会深究问题根源),但能够理解并解决这些问题是Java程序员进阶的必备要求.本文将对一些常用的JVM性能调优监控工具进行介绍,希望能起抛砖引玉之用.本文参考了网上很多资料,难以一一列举,在此对这些资料的

JVM性能调优监控工具jps、jstack、jstat、jmap、jinfo使用详解

是什么 jps 查看所有的jvm进程,包括进程ID,进程启动的路径等等. 我自己也用PS,即:ps -ef | grep java jstack 观察jvm中当前所有线程的运行情况和线程当前状态. 系统崩溃了?如果java程序崩溃生成core文件,jstack工具可以用来获得core文件的java stack和native stack的信息,从而可以轻松地知道java程序是如何崩溃和在程序何处发生问题. 系统hung住了?jstack工具还可以附属到正在运行的java程序中,看到当时运行的jav

(转)JVM性能调优监控工具jps、jstack、jmap、jhat、jstat、hprof使用详解

转:https://my.oschina.net/feichexia/blog/196575?p=3 现实企业级Java开发中,有时候我们会碰到下面这些问题: OutOfMemoryError,内存不足 内存泄露 线程死锁 锁争用(Lock Contention) Java进程消耗CPU过高 ...... 这些问题在日常开发中可能被很多人忽视(比如有的人遇到上面的问题只是重启服务器或者调大内存,而不会深究问题根源),但能够理解并解决这些问题是Java程序员进阶的必备要求.本文将对一些常用的JVM

JVM 性能调优监控工具 jps、jstack、jmap、jhat、jstat、hprof 使用详解

现实企业级Java应用开发.维护中,有时候我们会碰到下面这些问题: OutOfMemoryError,内存不足 内存泄露 线程死锁 锁争用(Lock Contention) Java进程消耗CPU过高 ...... 这些问题在日常开发.维护中可能被很多人忽视(比如有的人遇到上面的问题只是重启服务器或者调大内存,而不会深究问题根源),但能够理解并解决这些问题是Java程序员进阶的必备要求.本文将对一些常用的JVM性能调优监控工具进行介绍,希望能起抛砖引玉之用. 一. jps(Java Virtua

JVM监控工具用法指导

JVM监控工具用法指导 2010-09-27 15:39 dolphin-ygj javaeye.com 字号:T | T 通过JVM监控工具的使用可以及时发现问题,剔除安全隐患,这里向大家描述一下常用的几个JVM监控工具的用法,希望对你的学习有所帮助. AD:51CTO 网+首届APP创新评选大赛火热启动——超百万资源等你拿! 这里向大家描述一下JVM监控工具的用法,比如jstatd,启动jvm监控服务.它是一个基于rmi的应用,向远程机器提供本机jvm应用程序的信息.默认端口1099. JV

Java线程及Jvm监控工具

Java线程状态 线程的五种状态 * 新建:new(时间很短) * 运行:runnable * 等待:waitting(无限期等待),timed waitting(限期等待) * 阻塞:blocked * 结束:terminated(时间很短) Jvm监控工具 一.jstack 介绍: jstack用于打印出给定的java进程ID或core file或远程调试服务的Java堆栈信息.如果是在64位机器上,需要指定选项"-J-d64",Windows的jstack使用方式只支持以下的这种