10 LINUX使用MAT

本文介绍了如何在Linux环境中,针对JAVA应用、Tomcat、JBoss配置JVM参数,以便在出现OutOfMemoryError时生成hprof文件。详细步骤包括在Run Configuration中设置VM argument,修改catalina.sh文件,以及在Linux中的jboss配置。通过这些配置,可以在内存溢出时获取到heap dump文件,便于后续的内存分析。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.1  JAVA应用配置JVM参数,及生成hprof文件


右键,Run as è Run Conigurations..中的Arguments设置VM argument为:

-XX:+HeapDumpOnOutOfMemoryError

另外一种指定生成文件存储位置:

-XX:+HeapDumpOnOutOfMemoryError-XX:HeapDumpPath=/home/xieyun/test/TestHeapDumpOnOutOfMemoryError.hprof

生成的hprof文件,就在工程目录下。

具体分析请参见后面统一说明。

10.2    Tomcat应用配置JVM参数,及生成hprof文件

首先需要添加JVM参数。修改/home/xieyun/software/apache-tomcat-6.0.32/bin/catalina.sh

if [ -z"$LOGGING_MANAGER" ]; then

  JAVA_OPTS="$JAVA_OPTS-XX:+HeapDumpOnOutOfMemoryError-Djava.util.logging.manager=org.apache.juli.ClassLoaderLogManager"

else

  JAVA_OPTS="$JAVA_OPTS-XX:+HeapDumpOnOutOfMemoryError$LOGGING_MANAGER"

Fi

 

 

-XX:+HeapDumpOnOutOfMemoryError一定要放在最后,不然不会生效。

启动tomcat:

xieyun@xieyun-OptiPlex-760:~/software/apache-tomcat-6.0.32/bin$./startup.sh

UsingCATALINA_BASE:  /home/xieyun/software/apache-tomcat-6.0.32

UsingCATALINA_HOME:  /home/xieyun/software/apache-tomcat-6.0.32

UsingCATALINA_TMPDIR: /home/xieyun/software/apache-tomcat-6.0.32/temp

UsingJRE_HOME:        /usr/ali/java

Using CLASSPATH:      /home/xieyun/software/apache-tomcat-6.0.32/bin/bootstrap.jar

 

 

启动tomcat:

http://localhost:8080/testHeapDumpOnOutOfMemoryErrorWeb/HeapDumpOnOutOfMemoryErrorServlet

 

catalina.out输出:

2012-4-2320:41:16 org.apache.catalina.startup.Catalina start

信息: Server startup in833 ms

开始ThreadTest

开始ThreadTest

开始ThreadTest

开始ThreadTest

开始ThreadTest

开始SuccessThread

java.lang.OutOfMemoryError:Java heap space

Dumping heap tojava_pid31185.hprof ...

Heap dump filecreated [718127281 bytes in 27.183 secs]

Exception inthread "Thread-13" java.lang.OutOfMemoryError: Java heap space

         atcom.yxie.test.ThreadTest.run(ThreadTest.java:15)

Exception inthread "Thread-10" java.lang.OutOfMemoryError: Java heap space

         atcom.yxie.test.ThreadTest.run(ThreadTest.java:15)

Exception inthread "Thread-9" java.lang.OutOfMemoryError: Java heap space

         atjava.util.Arrays.copyOf(Arrays.java:2734)

         atjava.util.ArrayList.ensureCapacity(ArrayList.java:167)

         atjava.util.ArrayList.add(ArrayList.java:351)

         atcom.yxie.test.ThreadTest.run(ThreadTest.java:17)

Exception inthread "Thread-12" java.lang.OutOfMemoryError: Java heap space

Exception inthread "Thread-11" java.lang.OutOfMemoryError: Java heap space

 

生成的hprof文件在:

具体分析请参见后面统一说明。

10.3    Jboss应用配置JVM参数,及生成hprof文件

简单的linux jboss配置,和windowsjboss配置是一样的。需要修改run.sh文件。对应windows jboss配置修改就好啦。请参见: windows 平台使用Mat Jboss应用配置JVM参数,及生成hprof文件

 

Alibaba的项目,用的是jboss,如果我们需要生成heapdump可以使用jmp或者添加对应的参数。

1、  配置jvm参数

我是通过定时器来测试的。需要修改: /home/xieyun/work/standalone/superdeal/deploy/autoconf/promotionProductSoldOutNapoliTimer.sh.vm

JAVA_OPTS="-Xdebug-Xrunjdwp:transport=dt_socket,address=8787,server=y,suspend=n"

$JAVA_HOME/bin/java -Xmx512m -Dwget=true $JAVA_OPTS com.alibaba.intl.standalone.wholesale.superdeal.main.PromotionProductSoldOutNapoliTimer -XX:+HeapDumpOnOutOfMemoryError

2、  启动jboss,然后通过jmap命令生成对应hprof文件

jmap-dump:format=b,file=/home/xieyun/test/matTtempFile/heapDump.hprof 30146

3、通过mat工具进行分析。

 

 

Linux web应用intl-wholesale

需要修改/alibaba.intl.wholesale.deploy-1.0-SNAPSHOT/autoconf/env.vm文件。修改的代码对应

exportPRODUCTION_MODE=dev

$PRODUCTION_MODE= "dev"模式的代码。如:

elif [ $PRODUCTION_MODE = "dev" ]; then

    #we should reduce resource usage ondeveloping mode

    JAVA_MEM_OPTS=" -Xms64m -Xmx1024m-XX:MaxPermSize=128m -XX:+HeapDumpOnOutOfMemoryError-XX:HeapDumpPath=/home/xieyun/test/matTtempFile/TestHeapDumpOnOutOfMemoryError.hprof"

    JAVA_OPTS=" $JAVA_MEM_OPTS$JAVA_DEBUG_OPT "

   

 

启动服务。然后访问http://www.aliexpress.com:1080/proengine/release/displayPromotionMultipriceSearchBackDoor.htm

该页面会调用多线程导致outOfMemery错误。会生成hprof文件:


MAT工具使用说明.docx MAT(Memory Analyzer Tool)工具入门 一MAT简介 MAT(Memory Analyzer Tool),一个基于Eclipse的内存分析工具,是一个快速、功能丰富的JAVA heap分析工具,它可以帮助我们查找内存泄漏和减少内存消耗。使用内存分析工具从众多的对象中进行分析,快速的计算出在内存中对象的占用大小,看看是谁阻止了垃圾收集器的回收工作,并可以通过报表直观的查看到可能造成这种结果的对象。 二 使用MAT意义 当服务器应用占用了过多内存的时候,会遇到OutOfMemoryError。如何快速定位问题呢?Eclipse MAT的出现使这个问题变得非常简单。它能够离线分析dump的文件数据。 四 MAT操作流程 1先调用jdk的工具得到heap使用情况 我安装的是jdk1.6 C:/>java -version java version "1.6.0_11" Java(TM) SE Runtime Environment (build 1.6.0_11-b03) Java HotSpot(TM) Client VM (build 11.0-b16, mixed mode, sharing) 2调用jdk工具jps查看当前的java进程 C:/>jps 3504 Jps 3676 Bootstrap 3496 org.eclipse.equinox.launcher_1.0.201.R35x_v20090715.jar 3调用jmap工具得到信息 C:/>jmap -dump:format=b,file=heap.bin 3676 Dumping heap to C:/heap.bin ... Heap dump file created 这时,我们的C盘根目录,就生成了heap.bin文件。 4用eclipse的file---->open打开这个文件,首先是一个启动图: 这里可以选择查看 (1)内存泄露报表,自动检查可能存在内存泄露的对象,通过报表展示存活的对象以及为什么他们没有被垃圾收集; (2)对象报表,对可颖对象的分析,如字符串是否定义重了,空的collection、finalizer以及弱引用等。 我这里选择的是查看内存报表,以下是截的简略图: 通过报表展示,蛮清楚的,下面还有详细的说明,这里就没有帖图了,有兴趣的可以继续探究。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值