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中有记录,也可以从这个日志中看出内存分配的情况。 解决方法...
  • wangdachi
  • wangdachi
  • 2014年06月06日 11:45
  • 4625

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

一、java.lang.OutOfMemoryError: native memory exhausted Java 虚拟机初始堆大小和最大堆大小不能盲目设置 以前碰到不少做J2EE应用的同事。 他们...
  • u012454773
  • u012454773
  • 2015年12月29日 17:57
  • 2601

websphere 内存溢出处理

启用进程跟踪,可以产生native_stderr.log文件,通过分析工具分析分析这个文件,可以知道有哪些对象没有被释放等信息。默认WebSphere不启用这个功能,要启用这个功能参考http://w...
  • ppby2002
  • ppby2002
  • 2011年08月03日 10:23
  • 1656

websphere8 调整堆内存

前言 原来使用tomcat作为应用服务器,当需要调整堆内存的时候只需在catalina.bat文件中添加AVA_OPTS=%JAVA_OPTS% -Xms128m -Xmx350m 即可,本项目要求需...
  • metecyu
  • metecyu
  • 2014年09月19日 15:42
  • 2226

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

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

Websphere7.0环境下修改JVM的内存设置

方法1:修改配置的方式  通过修改server.xml进行JVM堆大小的设置: servel.xml文件路径:/IBM/WebSphere/AppServer/profiles/AppSrv01/co...
  • handi3
  • handi3
  • 2015年01月10日 20:32
  • 6789

jvm配置(内存溢出解决方法)

JAVA_OPTS参数说明与配置 最近手头的项目报内存溢出错误,内存溢出(Out Of Memofy) 错误信息:Java.lang.OutOfMemoryError: Java heap spac...
  • uTechCore
  • uTechCore
  • 2016年06月15日 16:29
  • 5480

jvm 内存溢出的多种原因及优化方法

让我们看一下我们日常在开发过程中接触内存溢出的异常:   Exception in thread "main" [Full GCjava.lang.OutOfMemoryError: Jav...
  • ZYC88888
  • ZYC88888
  • 2017年03月22日 10:33
  • 2446

websphere 修改内存配置信息

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

websphere 7.0 堆内存设置

各位运维同事,针对WAS服务器中JAVA虚拟机的配置,请留意一下这几个参数: -Xms JVM初始堆空间内存 -Xmx JVM最大堆空间内存 -XX:PermSize 永久存储区初始内存...
  • tstcylq
  • tstcylq
  • 2015年11月25日 10:06
  • 888
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:WAS 内存溢出(OutofMemory)问题分析常用方法
举报原因:
原因补充:

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