应用服务器发生内存溢出怎么办?两个工具帮你解决问题
对于B/S架构的应用J2EE应用系统,应用服务器发生内存溢出(OutOfMemoryError)错误是服务非常棘手的问题,解决问题的生内关键是要定位哪里出了问题。一般内存溢出的存溢出办原因有以下几类:

如:
-Xmx设置的比较小-Xms设置的过大sun的jvm没有设置-XX:MaxPermSize大小等等由于参数设置问题导致的内存溢出往往容易发现,调整一下参数,工具问题基本就可以解决。帮解
应用服务器缺少必要的决问补丁例如Websphere的某些版本存在很多性能缺陷,某些情况下也会导致内存溢出,应用打上补丁后,服务问题基本可以得到解决。生内
应用程序代码存在缺陷此类问题是存溢出办内存溢出最常见的原因,解决起来也最麻烦,工具本文主要描述这类内存溢出问题如何进行分析和定位。帮解
解决方案工欲善其事,决问必先利其器,应用有了好的工具,解决问题往往能起到事半功倍的作用,很多时候没有工具支持,b2b信息网问题很难解决。
本文主要涉及到2个工具的运用:
分析JavaCore的工具:IBM Thread and Monitor Dump Analyzer for Java。分析Heapdump的工具:Eclipse Memory Analyzer。通过这2个工具,一般的内存溢出问题基本可以定位。
在介绍这2个工具之前,先对一些相关概念做下解释说明:
Heapdump某一时刻Java进程内存的快照,记录当时内存中各对象的存储和引用关系等。Heapdump中不包含对象的调用信息,即无法从Heapdump中看出某个对象是哪段程序代码生成出来的。
JavaCore某一时刻Java进程中线程的快照,记录当时所有线程的执行堆栈信息等。JavaCore中可以看到各线程都在处理哪些程序代码,可以看到当前Java都在“做什么事”,在线程的执行堆栈中,有代码的调用信息,也有对象生成的相关信息等。
两种内存溢出内存溢出一般分两种,内存使用过度和内存泄露。免费源码下载
使用过度指在短时间内急剧耗尽大量内存导致内存溢出。内存泄露指长时间内,内存逐渐耗尽导致内存溢出,时间可能是几个小时或几天(通过开启详细垃圾回收可以清晰地观察到内存的分配情况)。Java系统的内存溢出大部分都是由于内存使用过度导致,内存泄露比较少见。本文后面介绍的也都是关于内存使用过度导致内存溢出的分析方法。
对于内存使用过度导致的内存溢出,可以通过Heapdump和JavaCore结合分析定位问题,对于内存泄露,主要还是分析Heapdump。
当Java进程出现内存溢出错误时,通常会生成Heapdump文件和JavaCore文件,例如Websphere部署的web应用,当出现内存溢出时,会在如下目录
/opt/IBM/WebSphere/AppServer/profiles/server1看到出现类似这样的文件:

Heapdump.*.phd文件记录Heapdump信息,javacore.*.txt记录JavaCore信息,一般内存溢出时会出现多个phd文件和JavaCore文件,分析时用其中一个即可。
下面就介绍如何通过工具分析这2个文件,如何通过对这2个文件的分析定位出内存溢出(内存使用过度导致)的服务器托管原
1. 分析 javacoreJavacore 的分析工具 IBM Thread and Monitor Dump Analyzer for Java(简称 JCA),以图形化的方式展现 java 线程的堆栈信息及相互关系等。下面是工具使用的截图:


对于 Websphere,主要关注 WebContainer 线程的执行堆栈情况,上图显示WebContainer:57 号线程的执行堆栈。Javacore 文件本身就是个文本文件,直接通过文本编辑器如 editplus 也可以打开,下面是用文本编辑器打开 javacore 文件后看到的WebContainer:57 号线程的执行堆栈:

可以看到,通过 JCA 打开 javacore 和通过 editplus 打开 javacore,没有本质的区别,只是展现形式有所区别而已,有关 JCA 工具的具体使用这里不作详细介绍。分析 javacore的重点是根据每个线程的堆栈信息找出哪个或哪几个线程导致 java 进程的内存溢出,对应线程堆栈中的代码段就是罪魁祸首。例如,如果通过分析得到 WebContainer:57 号线程可能导致内存溢出,那么 57 号线程中的这段代码就是问题所在。

为什么是 WebContainer:57 号线程有问题,而不是其它线程呢?这就需要结合heapdump 进行综合分析,下面会有详细介绍。
2. 分析 HeapdumpHeapdump 的分析工具推荐 Eclipse Memory Analyzer(简称 MAT),该工具比 IBM 的HA(Heap Analyzer)工具更强大,更易使用。下面是工具的使用截图:


该工具可以看到对象占用内存的大小、对象的个数等信息,通过分析占用内存比例最大的对象,可以初步判断是哪个对象导致的内存溢出,有关 MAT 工具的具体使用这里不作详细介绍。heapdump 分析的重点是找到占用内存最大的“业务对象”,所谓业务对象,就是和应用业务相关的对象,需要能靠到应用程序上。例如上图所示,虽然java.lang.String 比 DicRestrict 对象占用的内存要多,但是我们做分析时应该重点关注DicRestrict 对象,因为 String 对象是通用的业务无关对象,可能很多业务对象都会引用它。Heapdump 分析需要结合业务知识,需要相当的开发和业务经验。
3. 双剑合并Javacore 和 heapdump 的单独分析,都只是看到了事情的一面,通过一定方法将二者有机的结合起来,问题基本就可以水落石出了。
相关文章
- 摘要:随着电脑技术的不断发展,人们越来越依赖于电脑来处理工作和娱乐。然而,在使用电脑的过程中,有时会遇到电脑显示程序出现未知错误的情况,这给我们的工作和生活带来了一定的困扰。本文将介绍如...2025-11-04
 
图源:unsplash市场营销最强策略之一:在人们知道自己需要什么之前帮助他们意识到自己需要什么。这一点上,VSCode深谙其道。VSCode可能是目前最为流行的代码编辑器,就是因为它满足了每一个开发2025-11-04
在本文中,我想分享几个技巧,这些技巧将改善你的React代码。1. 解构 props在 JS 中解构对象(尤其是 props)可以大大减少代码中的重复。看下面的例子://ParentComponent2025-11-04
前几天在阿粉CSDN上看一个文章,因为一个Spring的问题,期望薪资三万却被生生的压榨成了两万五,高于两万五人家都不要,让我感觉到了Spring的强大,不学习Spring是会吃亏的,那么我们就从各种2025-11-04利用无peu盘装系统的教程及技巧(无peu盘装系统,实现简单高效,方便快捷安装)
摘要:在计算机安装系统时,通常需要使用peu盘来进行引导和安装。然而,对于一些没有peu盘的情况下,我们也可以通过一些技巧和方法来完成系统的安装,本文将详细介绍以无peu盘装系统的教程。...2025-11-04
受疫情影响,自春节开始,人们纷纷开启宅家模式,除了各种居家玩乐方式层出不穷之外,全国各地心系武汉疫情发展。火神山、雷神山医院开建以来,央视即为人们提供建设现场的24小时不间断实时直播,人们通过VR直播2025-11-04

最新评论