oom崩溃瞬间日志

环境:Mac+Win7(虚拟机)

oom崩溃是一瞬间的,就像车祸发生的一瞬间一样,如果没有瞬间的监控捕捉,事后再调查问题会很麻烦。

 

那如何将一瞬间进行监控捕捉呢,其实很简单,只要在JAVA_OPTS里面加一项即可,具体如下:

 

linux系统中

1.打开/tomcat_home/bin/catalina.sh文件 

2.加上:JAVA_OPTS="$JAVA_OPTS -server -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=D:\heapdump"

如下图位置:

 

注意:在linux中要加引号。

注意:上面有个HeapDumpPath表示发生OOM时,打到具体什么位置。否则不设-XX:HeapDumpPath时,dump出的文件在/tomcat_home/bin目录下

 

Windows系统中

1.打开/tomcat_home/bin/catalina.bat文件

2.加上:set JAVA_OPTS=%JAVA_OPTS% -server -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=D:\heapdump

如下图位置:

 

 

注意:通过这种方式打出来的内存快照非常大,而且和jstack打出来的格式是不一样的,jstack打出来的是那种Runnable,Waiting这种格式的。前者叫Heap Dump,后者叫thread dump,参考链接

 

那如何来分析这个内存快照呢,比较好用的是IBM的HeapAnalyzer.

1、从官网下载

2、在Mac的终端里输入如下命令:

java -Xmx4000m -jar ha456.jar /home/longhao/heapdump.out

3、打开后,点击Leak Suspect,里面可以看到到底哪个对象把堆塞爆了。

配置参考链接

配置参考链接2

参考链接

IBM Analyzer使用教程1

IBM Analyzer使用教程2

 

转载于:https://my.oschina.net/windows20/blog/892519

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值