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: