WAS 内存溢出(OutofMemory)问题分析常用方法

原创 2015年11月18日 11:09:40
WAS 内存溢出(OutofMemory)问题分析常用方法

简述 OOM(内存溢出):

内存溢出是指在应用系统中存在无法回收的内存或内存使用的过多,最终导致应用程序无法为新的对象分配内存空间,这时JAVA运行时会抛出一个 OutOfMemoryError 的异

常,简称 OOM。


简述 Java堆(Java Heap):

JVM 内存从逻辑上来说分为多个空间,Java堆是 JVM 所管理的内存空间中最大的一块。我们可以通过 JVM 启动参数 -Xms、-Xmx 来设定它的大小。GC 工作的主要区域也是

在这里,因为基本上所有的对象实例的内存都是在这里分配的。


简述 GC (垃圾收集器):

在 JVM 中,内存的释放是由垃圾收集器(GarbageCollection,GC)完成的,当一个对象不再被引用的时候,GC 便回收它所占用的内存空间。

-----------------------------------

触发内存溢出的可能原因:

1、集合类中(List、MAP)有对对象的引用,使用完后未清空

2、内存一次性加载的数据量过多

3、内存产生大量碎片,没有连续可用空间

4、代码中存在死循环或递归调用

5、JVM 启动参数内存值设定的过小

6、系统物理内存过小

-----------------------------------
在分析问题时,我们需要收集以下日志:

GC日志:native_stderr.log  (在 JVM 启动参数中加入 -verbose:gc 打开详细垃圾回收)

       通过 GC 日志native_stderr.log查看垃圾回收情况

应用系统日志:SystemOut.log

       查看具体错误信息


线程转储:javacore

       通过 heapdump 分析可疑泄漏对象


堆转储:heapdump

       通过 javacore 分析线程执行状态


------------------------------------

生成javacore和heapdump,可以多次收集,然后通过工具比较分析,这样更容易发现问题

[root@was01 bin]# ./wsadmin.sh -user wasadmin -password password
设置jvm环境变量
wsadmin>set jvm [$AdminControl completeObjectName type=JVM,process=server1,*]    
生成javacore文件:
wsadmin>$AdminControl invoke $jvm dumpThreads
找到JVM对象名字
wsadmin>set objectName [$AdminControl queryNames type=JVM,process=server1,*]
生成heapdump文件:
wsadmin>$AdminControl invoke $objectName generateHeapDump
------------------------------------

在 WAS 中,我们可以尝试以下方法,缓解内存溢出问题,具体方法请根据实际情况判断:

1、更改垃圾回收算法

2、优化 JVM 启动参数

3、增加 JVM 内存大小要想更好的解决 java.lang.OutOfMemoryError 的问题,我们需要从应用程序入手,因为优化程序带来的性能改善远远高于对 WAS 的调试。

-----------------------------------------

以下是对内存泄漏的几种分类:(摘抄自网络)

1. 常发性内存泄漏。发生内存泄漏的代码会被多次执行到,每次被执行的时候都会导致一块内存泄漏。

2. 偶发性内存泄漏。发生内存泄漏的代码只有在某些特定环境或操作过程下才会发生。常发性和偶发性是相对的。对于特定的环境,偶发性的也许就变成了常发性的。所以测试环境和测试方法对检测内存泄漏至关重要。

3. 一次性内存泄漏。发生内存泄漏的代码只会被执行一次,或者由于算法上的缺陷,导致总会有一块且仅有一块内存发生泄漏。

4. 隐式内存泄漏。程序在运行过程中不停的分配内存,但是直到结束的时候才释放内存。严格的说这里并没有发生内存泄漏,因为最终程序释放了所有申请的内存。但是对于一个服务器程序,需要运行几天,几周甚至几个月,不及时释放内存也可能导致最终耗尽系统的所有内存。所以,我们称这类内存泄漏为隐式内存泄漏。

版权声明:本文为博主原创文章,未经博主允许不得转载。

相关文章推荐

WAS 中JAVA内存溢出的解决方法

内存溢出是使用WAS时会经常遇到的问题。 1.现在WAS的控制台上打开详细垃圾回收。一旦出现OOM的错误时,会在nativeerr.log中有记录,也可以从这个日志中看出内存分配的情况。 解决方法...

WebSphere莫名自动重启\OOM问题记录

写给自己看的,做个记录。 应用在Tomcat下跑的妥妥儿的, 在WebSphere 7.0.0.7中部署时,经常会出现部署超时,内存溢出等异常;就算部署上了,WebSphere自动重启等问题也比较困扰...
  • wwwcomy
  • wwwcomy
  • 2015年10月13日 15:01
  • 908

was内存溢出:native memory exhausted(本地溢出)

一、java.lang.OutOfMemoryError: native memory exhausted Java 虚拟机初始堆大小和最大堆大小不能盲目设置 以前碰到不少做J2EE应用的同事。 他们...

websphere 修改内存配置信息

D:\IBM\WebSphere\AppServer\profiles\AppSrv01\config\cells\Template-2008Node01Cell\nodes\Template-200...
  • tstcylq
  • tstcylq
  • 2014年09月05日 14:19
  • 570

websphere性能设置和日常维护

一、 确认磁盘空间是否满足要求 1、 WebSphere 应用服务器自身代码的占用空间。这个空间一般在1G左右,在不同的系统平台上略有差异。  2、 概要文件所占的空间。WebSphere应用服务...

记录一次出差广东对中间件性能优化的完整报告

2014年1月份以来XX系统多次频繁出现访问量上去后,系统查询SQL语句提交到oracle数据库进行查询未及时返回时,很容易出现后台线程挂起,而XX系统并发数较高达到每一个节点200多个连接,总连接数...

WebSphere Application Server V8 中的垃圾收集,第 1 部分: 使用分代收集策略作为新的默认策略

简介 Garbage collection (GC) 是 Java Virtual Machine (JVM) 的必要组成部分,它收集没有使用的 Java 堆内存,以便应用程序可以继续分配新的对象。G...

解决mqsilist时报outofmemory内存溢出的问题和ulimit的用法

Running an mqsilist command results in a Java OutOfMemoryError Technote (troubleshooting) P...

OutOfMemory:PermGen Space & myeclipse tomcat内存溢出解决方法

Java程序员没有遇到过OutOfMemory简直就是不可能的事情! 可见在Java的世界中,太多的不确定因素导致Java运行程序直接崩溃,直接抛出OutOfMemory异常,而一旦遇到了这个问题,...

Android中图片过大造成内存溢出,OOM(OutOfMemory)异常解决方法(2)

在Android中:   1.一个进程的内存可以由2个部门组成:java 施用内存 ,C 施用内存 ,这两个内存的和必需小于16M,不然就会出现各人熟悉的OOM,这个就是熬头种OOM的情况。   2....
  • cqtddt
  • cqtddt
  • 2014年03月20日 12:05
  • 530
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:WAS 内存溢出(OutofMemory)问题分析常用方法
举报原因:
原因补充:

(最多只允许输入30个字)