JVM分析工具

1、JConsole可以图形化查看JVM中内存的变化状况,JConsole是JDK5及以上版本中自带的工具,位于JDK的bin目录下,运行时直接运行JConsole.exe或JConsole.sh(要求支持图形界面)。

如果要监视远程Java进程,需要在远程服务器上做相应的设置

1)windows系统下,需要修改 tomcat主目录\bin\ catalina.bat文件

将
set JAVA_OPTS=%JAVA_OPTS% -Djava.util.logging.manager=org.apache.juli.ClassLoaderLogManager -Djava.util.logging.config.file="%CATALINA_BASE%\conf\logging.properties"

修改成
set JAVA_OPTS=%JAVA_OPTS% -Djava.util.logging.manager=org.apache.juli.ClassLoaderLogManager -Djava.util.logging.config.file="%CATALINA_BASE%\conf\logging.properties"

-Dcom.sun.management.jmxremote

-Dcom.sun.management.jmxremote.port="8080"

-Dcom.sun.management.jmxremote.authenticate="false"

-Dcom.sun.management.jmxremote.ssl="false"

2)Linux系统下,需要修改 tomcat主目录\bin\ catalina.sh文件

增加一行

CATALINA_OPTS="$JAVA_OPTS -Djava.rmi.server.hostname=218.28.198.188 -Dcom.sun.management.jmxremote.port=9527 -Dcom.sun.management.jmxremote.authenticate=false -Dcom.sun.management.jmxremote.ssl=false"即可

然后使用JConsole就可以监控Tomcat啦。

点击%JAVA_HOME%\bin下的jconsole.exe即可

2、JVisualVM是JDK6update7之后推出的一个工具,它类似于JProfiler的工具,基于此工具可查看内存的消耗情况、线程的执行状况及程序中消耗CPU、内存的动作。

3、JMap是JDK中自带的一个用于分析JVM内存状况的工具,位于JDK的bin目录下。使用JMap可查看目前JVM中各个代的内存状况、JVM中对象的内存的占用状况,以及导出整个JVM中的内存信息。

在linux上执行jmap-heap[pid],就可查看整个JVM中内存的状况,看到的信息类似如下(和JDK版本、GC策略有关):

using thread-local object allocation.  
Parallel GC with 8 thread(s)  
Heap Configuration:  
   MinHeapFreeRatio = 40 
   MaxHeapFreeRatio = 70 
   MaxHeapSize      = 1610612736 (1536.0MB)  
   NewSize          = 524288000 (500.0MB)  
   MaxNewSize       = 524288000 (500.0MB)  
   OldSize          = 4194304 (4.0MB)  
   NewRatio         = 8 
   SurvivorRatio    = 8 
   PermSize         = 100663296 (96.0MB)  
   MaxPermSize      = 268435456 (256.0MB)  
Heap Usage:  
PS Young Generation  
Eden Space:  
   capacity = 430702592 (410.75MB)  
   used     = 324439936 (309.4100341796875MB)  
   free     = 106262656 (101.3399658203125MB)  
   75.32806675098904% used  
From Space:  
   capacity = 46333952 (44.1875MB)  
   used     = 13016424 (12.413429260253906MB)  
   free     = 33317528 (31.774070739746094MB)  
   28.092626331550566% used  
To Space:  
   capacity = 46792704 (44.625MB)  
   used     = 0 (0.0MB)  
   free     = 46792704 (44.625MB)  
   0.0% used  
PS Old Generation  
   capacity = 1086324736 (1036.0MB)  
   used     = 945707880 (901.8973159790039MB)  
   free     = 140616856 (134.1026840209961MB)  
   87.05572548059884% used  
PS Perm Generation  
   capacity = 100663296 (96.0MB)  
   used     = 46349592 (44.202415466308594MB)  
   free     = 54313704 (51.797584533691406MB)  
   46.044182777404785% used

导出整个JVM中的内存信息

通过以上方法能查看到JVM中对象内存的占用情况,但很多时候还要知道这个对象到底是谁创建的。例如上面显示出来的[C,只知道它占用了那么多的空间,但不知道是什么对象创建出的[C,于是jmap提供了导出整个jvm中的内存信息的支持。基于一些jvm内存的分析工具,例如sunJDK6中的jhat、EclipseMemoryAnalyzer,可以分析jvm中内存的详细信息,例如[C是哪些对象创建的。

执行如下命令即可导出整个jvm中的内存信息:

jmap-dump:format=b,file=文件名[pid]

4、JHat是SunJDK6及以上版本中自带的一个用于分析jvm堆dump文件的工具,基于此工具可分析jvmheap中对象的内存占用状况、引用关系等。

执行如下命令分析jvm堆的dump文件:

jhat-J-Xmx1024M[file]

执行后等待console中输出StartedHTTPserveronport7000,看到后就可以通过浏览器访问http://ip:7000了,此页面默认为按package分类显示系统中所有的对象实例。在页面的最下端有OtherQueries导航,其中有显示jvm中对象实例个数的链接、有显示jvm中对象大小的链接等,点击显示jvm中对象大小的链接

./bin/jhat -J-Xmx1024M /home/xxxxx/jvm.dump
Snapshot resolved.
Started HTTP server on port 7000
Server is ready.



Package <Arrays>

class [Lantlr.Token; [0xb276b450]
class [Lantlr.collections.AST; [0xb277f9b8]
class [Lcom.ctc.wstx.sr.Attribute; [0xb41af208]
class [Lcom.ctc.wstx.util.SymbolTable$Bucket; [0xb40db8b8]
class [Lcom.esotericsoftware.kryo.Kryo$Listener; [0xb0f18eb8]
class [Lcom.sun.jersey.api.client.ClientResponse$Status; [0xb63e6f98]
class [Lcom.sun.jersey.api.uri.UriComponent$Type; [0xb3e52ed8]
class [Lcom.sun.jersey.core.header.reader.HttpHeaderReader$Event; [0xb2f09368]
class [Lcom.sun.jersey.core.reflection.AnnotatedMethod; [0xb2dda758]
class [Lcom.sun.jersey.core.spi.component.ComponentScope; [0xb2ddf660]
class [Lcom.sun.jersey.core.util.KeyComparatorHashMap$Entry; [0xb2dfe068]
class [Lcom.sun.xml.bind.v2.model.annotation.AnnotationSource; [0xb484c3a8]
class [Lcom.sun.xml.bind.v2.model.annotation.Locatable; [0xb438baa8]
class [Lcom.sun.xml.bind.v2.model.annotation.Quick; [0xb438bd80]
class [Lcom.sun.xml.bind.v2.model.core.ID; [0xb43de388]
class [Lcom.sun.xml.bind.v2.model.core.PropertyInfo; [0xb484c6b8]
class [Lcom.sun.xml.bind.v2.model.core.PropertyKind; [0xb43dab20]
class [Lcom.sun.xml.bind.v2.model.impl.ClassInfoImpl$PropertyGroup; [0xb43d8d68]
class [Lcom.sun.xml.bind.v2.model.impl.ClassInfoImpl$SecondaryAnnotation; [0xb43c5e30]
class [Lcom.sun.xml.bind.v2.model.impl.PropertyInfoImpl; [0xb484c990]
Class 0xb3dba700

class [Ljavax.servlet.FilterConfig;

Superclass:

class java.lang.Object
Loader Details

ClassLoader:

org.apache.catalina.loader.StandardClassLoader@0xc0000690 (122 bytes)
Signers:

<null>
Protection Domain:

java.security.ProtectionDomain@0xc0018898 (58 bytes)
Subclasses:

Instance Data Members:

Static Data Members:

Instances

Exclude subclasses
Include subclasses
References summary by Type

References summary by type
References to this object:

jvm

相关推荐