使用OptimizeIT进行Java内存泄露的检测

Java程序也会引起内存泄露已经是公开的秘密了,工作中需要对该问题引起充分的重视。 

 

市场上能够进行Java内存检测的工具也有不少,我在工作中使用JBuilder自带的Optimize工具,现就最近一次使用Optimize的工程及经验进行以下梳理。 

 

前一段时间根据需要,对工作中维护的某个模块进行了Java内存泄露的测试,结果发现了很严重的问题:该模块一共有6大基本功能,每个功能每操作一次,大约要新消耗9-10k的内存空间,生成110个左右的新对象。作为商用软件产品是绝不允许这样的问题的出现的。 

 

OptimizeIT有整合进JBuilder版本,也有单独的版本,使用起来基本上都是一样的,它有4大功能,能够进行内存profile、cpu的profile、代码的覆盖率的检查以及threads debug等,能够对普通应用程序、jsp/servlet以及服务器请求等进行剖析。其它的没有用过,这次主要使用内存profile,发现这个东东比较好用。

 

下面介绍怎样使用OptimizeIT工具进行内存泄露的检测和解决。 

 

先说检测的思路:程序运行从一种状态进,经过运行,返回到初始状态,中间过程会产生很多的对象,而这些中间产物最终是应该被清除掉,如果没有被完全清除,就说明程序中有了内存泄露。换句话说,通过比较程序运行前后两种状态下,堆内存中的对象的种类和数量的多少,可以判断出程序中有没有产生内存泄露。当终了时刻,程序堆内存里面对象的种类和数量比初始时刻多,基本就可以确定程序中存在内存泄露了。 

 

接着说,这次使用OptimizeIT检测的过程。

 

1、首先使用JBuilder建立一个可运行的工程,再进行工程运行属性的配置的时候,可以同时进行OptimizeIT的配置,主要是选择内存泄露选项以及其它的可选项,不过很少用。 

 

2、点击工具栏上的Optimize按钮,开始检测,该按钮位于程序运行按钮的右边,带有一个秒表的样式。 

 

3、Optimize启动之后会展示几个Tab页视图,我们主要关心内存视图。 

 

4、默认在内存视图中显示的是堆内存视图,通过在该视图下方输入过滤条件,在该视图的中部,可以得到我们关心的类的对象实例情况。 

 

5、运行程序到某一个初始状态。 

 

6、回到Opimize,运行垃圾回收器,为了尽可能调动GC,建议连续运行GC三次以上(简单的说就是多点击几下按钮而已)。 

 

7、对当天的状态进行标记,也就是点击一下视图右上角的带铅笔样式的图标。 

 

8、行程序的功能,然后关闭该功能,使程序退回到原来的状态,基本上就是在Optimize上作标记时刻的界面样子。 

 

9、Optimize堆内存视图,多次进行GC。 

 

10、timize报告出,从最近一次做标记以来内存对象(实例)的变化情况。由于我们已经进行过滤,所以imize不会显示我们关心的包(或者类)以外的对象的情况。 

 

通过这种比较,我们可以发现程序中是否有内存泄露。