欢迎大家来到测试人生,在你休息的时候你可以畅所欲言,空间里也许有些资料可以帮助到你,来吧,朋友,测试人生欢迎你!!!!

日志 [2013年01月08日]

上一篇 / 下一篇  2009-06-04 11:31:23 / 个人分类:性能测试

51Testing软件测试网9pHcn't ]M1z

昨天项目上线测试发生了Out of Memory的JVM错误,导致系统down掉并且服务器文件系统撑爆。检查原因是出现过多内存泄漏,系统的可用内存和性能持续下降;最终将导致内存不足(OutOfMemory)。我们开发用的是IBM WebSphere平台,在websphere/AppServer下生成大量javacore*、heapdump*之类的文件,致使websphere的垃圾回收功能失败而导致。其中,javacore文件是关于cpu的,heapdump文件是关于内存的。

M)D ?$s WZO[u0

8DsNR5}toy0生产环境是ibm小型机,按照手册修改了:应用程序服务器 > server1 > 进程定义 > Java 虚拟机,将"最大堆大小(默认为256)"改为768或1024以上。删除文件系统中的javacore*,heapdump*后基本恢复正常。分析原因,一是JVM设置问题,二(最终原因)程序不够健壮,很多资源没有即时释放导致资源撑爆。尤其是数据库连接资源。以前也遇到过进程挂起的情况,与此次不同,进程挂起主要原因是SQL查询不能及时返回结果导致页面一直等待资源返回而挂起(suspend)。三是产生大数据量的结果集返回结果。一直怀疑我们用的数据结构不够合理,但是也没有尝试修改。

/b5p-nj,[pFy051Testing软件测试网4^-\ c&o9x.i

总结一下:51Testing软件测试网1I:g-C4ywuw

P0S9{&Fq~,bHI\0关于架构应该使用健全的模式,使用资源后要及时释放和回收垃圾;

s9Et O"g2XH3n0

&b4k {J(V#kj)CU0尽量采用分布式的结构,类似MVC模式;

[8}(y#p)y8`%H051Testing软件测试网:dv?n*L/a {P4e|

努力从程序上解决根本问题。51Testing软件测试网:]!~3C!Ta

(H ^_#c;oC9zg0附:转载

({0lMp"B051Testing软件测试网$PU3T6YZ ttu7W

WebSphere应用服务器内存泄漏探测与诊断工具

,cpS'ir0s/]/d0

(@(@P8u)mwv7b0级别: 中级 李 学朝 (lixuec@cn.ibm.com), 高级软件工程师,IBM中国软件开发中心51Testing软件测试网)Y P8i4P NS.]

51Testing软件测试网/\ BN)G o+[ P

2006 年 11 月 21 日51Testing软件测试网G,uD6eH-[8q{

r/k&G-Fg#@ LD0本文介绍了如何在WebSphere应用服务器中实现应用程序内存泄漏的探测,并且针对IBM所提供的系列分析与诊断工具,给出了具体的配置步骤和使用最佳实践。
1pP"s0} n%k `M0引言

|?8U*r?J051Testing软件测试网jQTC~)Op

内存泄漏是比较常见的一种应用程序性能问题,一旦发生,则系统的可用内存和性能持续下降;最终将导致内存不足(OutOfMemory),系统彻底宕掉,不能响应任何请求,其危害相当严重。同时,Java堆(Heap)中大量的对象以及对象间之复杂关系,导致内存泄漏问题的探测和分析均比较困难,采用相应的辅助工具是很必要的。

5uwNC2_v8l p051Testing软件测试网o ~tu-u#t

WebSphere应用服务器提供了系列针对内存问题的探测和分析诊断工具,这些工具可以帮助用户进行内存问题的及时探测,保证系统在发生OOM之前,用户可以在无须进行复杂分析的条件下,预知在其部署的应用中是否存在内存泄漏的问题。如果确有内存泄漏现象发生,WebSphere还提供了相应的工具,可以帮助用户进行分析诊断,从而找到内存泄漏的真正原因。51Testing软件测试网tD:DVt

51Testing软件测试网)tL&H@uO9?

1. 内存泄漏探测和诊断步骤

[8VDx*S8BO A7c0

]` ~I(X!c4{L{(e0实践中,我们可以采用以下的步骤来处理内存泄漏的问题:

1ezM~#H2WfSZO051Testing软件测试网 j y&@E^

(1) 首先,在WebSphere中我们启用实时探测内存泄漏工具, WebSphere性能诊断顾问会对内存泄漏提前发出警告信息。

'Y.OONi&I2o mm k0

%bc7o3V r2G0(2) 启用WebSphere自带的Tivoli性能查看器监视系统的JVM使用状况,确定内存泄漏是否正在发生。

aW ~ F$L.g051Testing软件测试网 H#h4h tp\6F

(3) 根据需要,生成详细内存回收日志,使用PMAT工具分析并确定泄漏的时间,周期等。51Testing软件测试网g^ PK ij8G#o%QL

51Testing软件测试网uO8b Nuq8W1oO

(4) 生成单个或者多个Heapdump文件,选用MDD4J进行分析诊断,找到内存泄漏的真正原因。51Testing软件测试网 Fn r;h5j%f[,|{

-IA#R0X0X%t"m0G0(5) 提交开发部门进行代码修复,然后重新部署到WebSphere应用服务器。

)m~T,[x(c q{'i051Testing软件测试网`-d5Cq;p.z0m,h

接下来的部分,我们针对每个环节的配置和工具使用进行阐述。51Testing软件测试网j+M+G)q!J0wCZ

51Testing软件测试网O2MM)C3F{-J^

2.WebSphere应用服务器中内存泄漏的探测工具

G){?op)M`051Testing软件测试网\!p8o~r\5O].qa

2.1 性能诊断顾问介绍51Testing软件测试网?+Qs#a#MpWgf

$D'd IxJ't q;tK[0性能诊断顾问(Performance and Diagnostic Advisor),在WebSphere应用服务器6.0.2版本之前称为运行时性能顾问(Runtime Performance Advisor)。该工具可以周期性的检查WebSphere的设置,并给出调整的推荐值。自WebSphere应用服务器6.0.2版本开始,该工具实现了一种轻量级的内存探测机制,可以非常容易的帮助用户探测是否在系统中存在内存泄漏问题,并提前通过日志和管理控制台进行通知。这样就给用户以足够的时间采取必要的措施防止系统宕掉,同时可以收集或生成相关的文件以进行离线的分析,来查找泄漏的根本原因。

\5?J p]U0

Rdu.I+ZHTB02.2配置

C!Fp$Q M4y~051Testing软件测试网|Ol nH5j{$wQ

可以在WebSphere应用服务器的管理控制台中启用性能诊断顾问51Testing软件测试网~tS&G|I zuv)ET S x

5Xh9B\'Gz#Fw0(1) 访问管理控制台 ->服务器-> 应用程序服务器。51Testing软件测试网-[H0?;I-yj

-D6s;Gg@|;@0(2) 选择所要配置的服务器。51Testing软件测试网!B(ja&a!t;[&C&qf

51Testing软件测试网jO4t8M/]9ah%v nv

(3) 在性能区域,选择性能和诊断顾问程序配置。51Testing软件测试网r1a*A8a+sZ

51Testing软件测试网b p@1IW.r+{i"o!W

(4) 如图所示,有两个Tab, 运行时和配置。区别在于,运行时里面的内容无须重启服务器就可以生效,但下次重启服务器的时候,这些配置也会丢失。配置Tab里面的内容只有在服务器重启后才生效,而且配置的内容也会一直存在,除非再次登陆并去掉所选项。51Testing软件测试网b|OK$]/c&|,fNQ

51Testing软件测试网)sK8@t.wFNL~

(5)在其他属性区域,点击性能和诊断建议配置,确保内存泄漏规则处于运行状态(绿色箭头)。51Testing软件测试网r*X1v~z7A

51Testing软件测试网Qz[(o@*[A

2.3 查看泄漏警告信息51Testing软件测试网2M3O9eFo#V

9[jl)ZJL`k0WebSphere性能诊断顾问输出信息可以显示在WebSphere的管理控制台,并记录在WebSphere应用服务器的SystemOut.log日志文件里面。51Testing软件测试网 ]Ms~$e9v*m

51Testing软件测试网xo%cJJ,y @

(1) SystemOut.log日志

BT#w4g%VA7OM#E051Testing软件测试网5a9T8]1d,O j `+S

 [8/31/06 13:21:43:545 CST] 00000010 TraceResponse W   TUNE9001W:  Heap51Testing软件测试网D6]#l"a lz!];b
 utilization patterns indicate that you may have a memory leak51Testing软件测试网Wre-d9\Q(U
Additional explanatory data follows.51Testing软件测试网$w R k6L*r:JtPWR Y*F
Data values for free memory between 8/31/06 1:20 PM and 8/31/06 1:21 PM were51Testing软件测试网7rcr}7P-J.R `
consistently below minimum required percentage.

sR_U Bv"T0

*t}`"|A0(2) 管理控制台51Testing软件测试网C nCIDb

8n V$sDqY)XM-I0-登陆管理控制台->故障诊断 ->运行时消息 ->点击运行时警告51Testing软件测试网'Q:V$^-UQg7lWw

51Testing软件测试网Z y(F6DwCC!ls

3. Java 虚拟机概要分析和详细垃圾回收51Testing软件测试网T"{sB.@ k#c1]x

51Testing软件测试网ZNcD$?j BC0u%K

进一步检测是否有内存泄漏的发生,以及泄漏发生的时间,周期和速度,我们可以启用Java虚拟机中的详细垃圾回收,然后分析相应的日志。 WebSphere应用服务器6.1使用了Java SDK5.0, 在Window, Linux, AIX, i5/OS,z/Linux 和z/OS上使用了IBM的JAVA虚拟机, 在Solaris和HP-UX上使用Sun的JVM。Java 虚拟机概要分析工具接口(Java Virtual Machine Tool Interface,JVMTI)支持从运行应用程序服务器的 Java 虚拟机(JVM)收集信息(如,关于垃圾回收的数据、对象利用和线程状态)并且支持更全面的性能分析。一旦启用了 JVMTI,可以使用 PMI 定制选项来启用所选统计信息以收集特定数据。51Testing软件测试网M{QU D|

fN9i!M6BT03.1启用 Java 虚拟机概要分析和详细垃圾回收配置步骤51Testing软件测试网 ] `/[uK]vJ3C

51Testing软件测试网#wz.A3dmI3k o1u

配置步骤:

4m#x I/t|)}H7g0

k/JjX$J kT/n;?01. 在控制台导航树中单击服务器 > 应用程序服务器51Testing软件测试网 U h_z z+g x

#sUn|t'I3f_02. 单击选择所需应用程序服务器。51Testing软件测试网2aXJ1X e-@4a ^4W

51Testing软件测试网Lvi(y;{r5c

3. 在"服务器基础结构"下,单击 Java 和进程管理-> 进程定义。51Testing软件测试网2t/u2^T C w tR

51Testing软件测试网1y[Q%h I5g

4. 在"其他属性"下,单击 Java 虚拟机。

a8m6^ `P0

&gO/F3s[/B05. 选中配置Tab的详细垃圾回收选项。

_Tyey R0

%o'q{NB-U l06. 在通用 JVM 参数字段中输入 -agentlib:pmiJvmtiProfiler。51Testing软件测试网:vsb`QDZ

Z9m7W9s7Pb0注: WebSphere6.1中,JVM概要分析接口改为Java Virtual Machine Tool Interface (JVMTI)。之前版本是JVMPI。如果需要JVMPI的时候,也可以此处输入-XrunpmiJvmpiProfiler。另外,启用JVMTI接口对性能影响较大,尽量避免在生产环境中使用。51Testing软件测试网 \7Q a$Lg!{F v5k

AR2P ~2g+@D07.点击应用或者确定。

f#y.d(|y/N0

t!Iz1S!^2c/s08. 单击保存按钮。

D#zqP$@(A051Testing软件测试网I5rvE3H? d+z8]"s

9.重启WebSphere应用服务器。51Testing软件测试网OU0g|m$C4e(nBp

3UUg,sib|03.2 GC数据分析工具PMAT

#r7i f @9M%Yi*o6L051Testing软件测试网k Sl%fy

在WebSphere应用服务器的日志目录下,native_stderr.log文件就是我们需要的内存回收分析文件。我们推荐使用IBM Pattern Modeling and Analysis Tool for Java Garbage Collector 工具,简称PMAT。 PMAT工具解析JAVA SDK的详细内存回收(GC)日志,并提供统计信息,图表,分析并推荐Java堆配置。PMAT提供了丰富的图形界面来显示Java堆的使用状况,从而更轻松地判断是否有内存问题发生。该工具可以从IBM的alphaWorks网站下载,只有英文版。

*NWFsVA^6U.bw!`0

4hT6zxP0C n8Ed(d&K0我们可以把GC文件从服务器上下载到PMAT所在机器,然后根据WebSphere的平台选择打开相应的GC文件进行分析。下面是一个GC日志片断,手动分析是比较费劲,而且需要深入了解JVM相关知识。

Q&QTC.r.q p0

H/d4|!Bz ]7U.a l1s9~:u0PMAT在分析GC日志后,给出一个总结。下图为例,我们可以看出GC对系统性能的影响,以及完成的垃圾回收次数等,并且我们可以看出工具给出的推荐(Recommendations)显示系统的Java堆使用情况是持续增加的。

5alp!Q;z0

m(Ww+N0a1a(|0进一步,我们可以查看GC的详情,点击Analysis菜单,然后选择Graph View All,我们就可以根据需要选择所要查看的曲线。如图所示,红色曲线代表已使用内存,蓝色曲线代表每次垃圾回收后可用的内存。已使用内存逐渐增加,可用内存的持续降低表明系统可能存在内存泄漏。51Testing软件测试网pfb0h'Q/z

51Testing软件测试网/^!`+h V%z.I

4. TPV监视JVM的状况51Testing软件测试网o7E!o p0?UM

51Testing软件测试网)dI3S3{{0y#\$PZw8S

另外一种方法是借助TPV和PMI来实时监视JVM,分析性能曲线来判断是否有内存泄漏的状况发生。 WebSphere性能监控基础结构(PMI)和Java虚拟机概要分析工具接口(JVMTI)可以帮助我们收集系统的性能状况数据,使用Tivoli性能查看器(TPV)以图形的方式显示这些数据(性能计数器),可以进一步证实是否系统正在发生内存泄漏。51Testing软件测试网:vNHH4o1k/?&SB,Q

s4RVl%X@hGM04.1 PMI与TPV

)|8r(h'pF051Testing软件测试网 M3VM#SMb$M&C

PMI 提供WebSphere运行时和应用程序资源行为的一组全面的数据,。例如,PMI 提供数据库连接池大小、servlet 响应时间、 Enterprise JavaBeans(EJB)方法响应时间、Java 虚拟机(JVM)垃圾回收时间以及 CPU 使用量等等。使用 PMI 数据,可以识别并修正应用程序服务器中的性能瓶颈, 还可使用 PMI 数据来监控应用程序服务器的运行状况。PMI 数据可以由 Tivoli Performance Viewer(TPV)、其他 Tivoli 工具、您自己的应用程序或第三方工具来监控和分析。TPV 是随 WebSphere Application Server 一起提供的 PMI 数据图形查看器。

a Qw#OS5Rot0

6RU._4J/Y0Tivoli Performance Viewer(TPV)使得我们可以通过查看图表或表格,从而解读WebSphere的性能监控基础结构(PMI)数据。51Testing软件测试网{$xg's%?$s-j

YfW `c,`04.2 PMI的配置方法51Testing软件测试网5~Z%?E-M ~8F

|j1?C Wz&C uK0默认情况下,PMI已经开启,级别是默认(Default)。配置步骤:

~M Q"hNKy051Testing软件测试网Axb ot

1. 在控制台导航树中单击监视&调整-> 性能监视基础结构(PMI)。

2K9t%jat-s_5\051Testing软件测试网 fz2`2hr-Rs R/w

2. 选择所要配置的服务器名字。

/~ U5Z]}${0

2Dh'e/xyq:E03.单击配置选项卡,这里可以根据监控内容的需要,来选择PMI的任一种统计信息集(无,基本,扩展,全部,定制)。我们这里选择"定制"。

K h&?NL D\*Q051Testing软件测试网3n%R;H%n"u!z

注:如果在配置选项卡中,则当重新启动服务器时应用设置。如果在运行时选项卡中,则立即应用设置。51Testing软件测试网j*k*o}?

51Testing软件测试网bCU:XI7@&}qy'`^G

4.点击定制 -> 在定制监视级别的树中,选择配置选项卡,然后点开JVM运行时,可以根据需要,启用或禁用相应的计数器。

c/z*V&N,[H8{051Testing软件测试网K3FOVh o

5.保存并重启WebSphere服务器。51Testing软件测试网AorZ-lm6c

51Testing软件测试网0~xz g#WR5U'Z7t

4.3 TPV的使用方法51Testing软件测试网b| y1ovL0[/rDk

51Testing软件测试网ob} B\

实时查看 TPV 性能模块的步骤:

iM*[)A#kn0

*G6DD`k+Lp0(1) 在控制台导航树中,单击监控和调整 -> 性能查看器 -> 当前活动 -> 服务器名字)-> 性能模块。51Testing软件测试网7y"MJ7a:NyiSpT^

51Testing软件测试网 hJW,G(gq

(2) 选中要查看的每个性能模块,例如JVM运行时。51Testing软件测试网1^!NnblU {

D,j|YMX A-N0(3) 单击查看模块按钮。 在页面的右侧会显示所选性能数据的图形或切换成表格。注:每个模块有与其关联的多个计数器。这些计数器会显示在数据图形或表格下面的表中。您可以通过选择或取消选择计数器旁的复选框,将计数器添加到图表或表中,或从中除去。

5F)QiQ{jCE x051Testing软件测试网;J}0q9T.jf1v%y

TPV显示的已使用内存的图形理想情况下应该是锯齿状,图形中每个坡(下降)对应着一次内存的垃圾回收(Garbage collection),如下图已使用内存的曲线,显示的是没有发生内存泄漏的状况。

Q3t2~%J6Z&RO_0

rLr3ES-z_0如果测试过程中出现如下情况,则有可能发生了内存泄漏:51Testing软件测试网m&lY"F] t _ho^

z'S.o!H1RZR/kTSm0-每次垃圾回收后的已使用内存的数值骤增。51Testing软件测试网rk7yk!Pka

#p%X/vY qV|YJU0-TPV对应的已使用内存图形更接近于阶梯(staircase),或者锯齿形状严重不规则。

^*Z8HE[nWC]*y_0

HT%EW%]0-也可以查看分配的对象数与释放的对象数之差值,如果这个数值越来越大,则有内存泄漏(如果需要查看对象数,需要启用JVMTI接口并在PMI中启用相应的JVM计数器)。

tU4I)S,Vt+`,QX051Testing软件测试网9u^e s)O"p1J

上图,红色曲线代表已使用的内存,从整体趋势,我们可以看出已使用内存一直在增长。 TPV可以帮助发现内存泄漏,为了得到最优结果,我们可以重复试验,而且每次可以增加测试的时间,例如测试1000,3000或5000个页面请求。

'D:} }O,}w%f.lQ+b0

5t8Mi7\;U @6v/{Q9N05. 生成Heap dump文件51Testing软件测试网"Z0f+OXGE3`u

51Testing软件测试网7rTc m6__T\

WAS6.1中,在使用IBM JDK的平台上,可以直接使用以下的方法,随时生成所需的heapdump文件。如果在性能诊断顾问程序配置里面选中了"启用自动堆转储收集,则可以自动在WebSphere profile所在的路径下(例如/opt/IBM/WebSphere/WAS6.1/profiles/AppSrv01)生成heapdump文件,备用户进行分析。

EK\!_#a$P}4|051Testing软件测试网5xG`7~,`FN7A-m2y

在使用IBM SDK的平台上,例如AIX, Linux和Windows,在启用了性能诊断顾问工具后,如果探测到有内存泄漏发生,WebSphere会自动生成两个heapdump文件,供后续分析使用。51Testing软件测试网ADW8N/DK7~

Rg!Z`v5ky9l0我们在任何时候,可以随时手动生成所需的heap dump文件。在WAS6.1 profile的bin目录下,首先运行wsadmin 脚本客户端,然后可以调用generateHeapDump操作来完成。51Testing软件测试网 SA X*`I/k

51Testing软件测试网*o2]#s1wj?zH

关键步骤:51Testing软件测试网|$N v5nP3fP(Y

51Testing软件测试网&zN)EDqz m]s

1. 找到JVM对象名字。

'l?zY r.h ~:O0

.R"ynxb9~ ~0set objectName51Testing软件测试网}3OEak`&c
WebSphere:type=JVM,process=,node=<节点名字>,*]51Testing软件测试网-s_ H j1Z/e-B;H
2. 对JVM MBean调用generateHeapDump操作。

(eGp o9b0?&u051Testing软件测试网D,d&G_#B+sE

$AdminControl invoke $objectName generateHeapDump51Testing软件测试网-t+cb0e}f"b]
例如:

&GK$_.Z\051Testing软件测试网cS"x}!v1b#} c

[root@csspvm bin]# pwd51Testing软件测试网 _a"D/Vh3@
/opt/IBM/WebSphere/WAS6.1/profiles/AppSrv01/bin
P4\5u7YQ1_2Y6G(P5h0[root@csspvm bin]# ./wsadmin.sh -username root -password demo4you
:i[k/wK0WASX7209I: Connected to process "server1" on node csspvmNode02 using SOAP51Testing软件测试网K w%k'C)b7pN6A t
connector;  The type of process is: UnManagedProcess
L ]e+_"^N[w0WASX8011W: AdminTask object is not available.
xQ b8]ZE|0WASX7029I: For help, enter: "$Help help"51Testing软件测试网tyP ~`'v&f*DP
wsadmin>set objectName [$AdminControl queryNames51Testing软件测试网(`2jm C/_C \!ZX
WebSphere:type=JVM,process=server1, node=csspvmNode02,*]
4@"q^ ~6c/N0WebSphere:name=JVM,process=server1,platform=proxy,node=csspvmNode02,
m V z-|#J%e9{k%N9`0j2eeType=JVM,J2EEServer=server1,51Testing软件测试网3m DG9E3L8C;u
version=6.1.0.0,type=JVM,mbeanIdentifier=JVM,cell=csspvmNode02Cell,spec=1.0
(dZE'n%aTfN0wsadmin>$AdminControl invoke $ objectName generateHeapDump51Testing软件测试网!d0~^J*M[
/opt/IBM/WebSphere/WAS6.1/profiles/AppSrv01/./heapdump.20060904.075650.3576.phd51Testing软件测试网Ut:~ `e{$~p[ V
wsadmin>quit
w(vuX!s[l0 51Testing软件测试网 ^m Btl;E'{

&av6{1{@#tOC0理想情况下,在探测到问题时,尽快生成一个初始的heap dump,然后密切监控内存使用情况,等到泄漏了足够的内存的时候,再生成另外一个heap dump,这样可以对比分析以更准确地找到泄漏的原因。

4w*H&~.f },Ma At0

&FU`INj^2w0注: 生成HeapDump文件的过程是比较耗资源的,所以请只在必须的时候做这样的操作。

*d4_2|9E4tSRj051Testing软件测试网uft!s{'p'{1]

6内存泄漏的分析诊断工具-MDD4J51Testing软件测试网 UU S;}%rOq

T c;@,]9eT_8J0一旦确定了系统中有内存泄漏,并且为此生成了heap dump。接下来,我们可以把这些文件从WebSphere应用服务器转移到离线的分析工具所在的机器,进行离线分析诊断。

*Fjdi(|:g;Ek0

Dt Nn)Qef/Wg`f8u06.1 工具介绍51Testing软件测试网 Y`+R.P D8?9]

51Testing软件测试网dMY%Zb X

MDD4J(Memory Dump Diagnostic for Java)是一个内存泄漏分析工具,用于对运行 WebSphere Application Server 的虚拟机(JVM)所生成的常用内存转储(堆转储)格式进行分析。进行内存转储(Memory dump)分析的目的,是为了确定 Java 堆中真正导致内存泄漏的类和包(classes and packages),这样可以缩小内存泄漏的范围并找到真正的原因,此分析还确定应用程序 Java 堆占用量的主要组成部分以及它们之间的拥有关系。

)RH]0^.w"b&d0

X V)s$ni2sUmS0此工具支持下列格式的内存转储格式有:51Testing软件测试网:F[q$Gz

51Testing软件测试网Mgp&`z,c)\^-l

-IBM 的PHD格式(heapdump.phd)51Testing软件测试网Cb1nH&z!P

51Testing软件测试网 G}Oa/W2jo+I

-IBM 文本堆转储(heapdump.txt)

+Ac7f A~G0

gN [4n,S0-HPROF 堆转储格式(hprof.txt,主要针对Solaris和HP-UX平台)51Testing软件测试网 qi0G/jo7e(H

51Testing软件测试网aq2v&\g8FYp

-SVC 转储(dump.bin,IBM z-Series上的WebSphere)

{h1~T/q8L0

4FPnm5eR0该工具提供了两种分析机制:单转储分析以及对两个转储进行的比较分析。51Testing软件测试网;@!F,pYk/l*D;R8\

51Testing软件测试网} o}-rw&a,O"U

单转储分析最常用于在发生 OutOfMemoryException 时自动触发的内存转储。此类分析查找可疑的数据结构,能够相对快速地提供可疑泄漏对象的分析结果。

h4Pq4L M1K8po-zK051Testing软件测试网0M%ctb4F+G

比较分析用于对运行内存泄漏应用程序期间(即可用 Java 堆内存流失时)获取的两个内存转储进行分析。在运行泄漏应用程序的早期触发的内存转储被称为基线内存转储,发生泄漏的应用程序运行一段时间(以允许泄漏程度加大)后触发的内存转储被称为主内存转储。在发生了内存泄漏的情况下,主内存转储可能包含大量对象,而这些对象占用的 Java 堆空间量会比基线内存转储大很多。51Testing软件测试网6ju m LUi)d

^Qrh(bMNCXj0为了获得更好的分析结果,建议使主内存转储的触发点与基线内存转储的触发点在时间上拉开一定距离,从而使总耗用堆大小在两个触发点之间大幅增长。51Testing软件测试网9pok#R|$X3fwX

TCOd+lm|!n8J0MDD4J的分析结果显示是基于WEB界面的,具有下列特征:51Testing软件测试网!u6Y5w4@qY,HF

51Testing软件测试网K\B(}x$Xbt5t@

- 列示分析结果、堆内容、大小和增长幅度的总结

i2U[Mx*H5Vm&s051Testing软件测试网d2\)cy8S `!u

- 列示可疑的数据结构、数据类型和包,它们是造成堆使用量增加(对于比较分析)和堆大小较大(对于单转储分析)的主要原因。

9E`S7@j @:di0

c#[Ei `1m8r0- 拥有关系上下文视图显示了占用量主要组成部分之间的关系,以及一组汇总的主要占用量组成部分所包含的重要数据类型。51Testing软件测试网!?)}e yT:J+L

dw.}1h%k1{ ncg v3d Y0- 在堆转储内容的交互式树形视图中,浏览功能能够显示堆中任何对象的所有进入引用(在树中只显示一个引用,其余引用单独显示)和外出引用,而子对象按到达大小排序。51Testing软件测试网(L$l"T7?6ZHE"j A hu

l L{[~4DWl(L.Av0- 导航功能使您能够从可疑对象列表转到所有关系上下文,以及从内容视图转到浏览视图。51Testing软件测试网Y:U\,U-ZH,QG

I-V0S:K9v0i&Mp"g4dx0- 提供了内存转储中所有对象和数据类型的表视图,视图中具有过滤器和经过排序的列。51Testing软件测试网P^!Al9R:X

51Testing软件测试网^@D5p%Ev

6.2工具的使用51Testing软件测试网.eRI@_8p

51Testing软件测试网8P:qnE.R e0~)t

WebSphere 应用服务器v6.1的附带光盘里面有IBM Support Assistant工具的安装文件,运行相应的安装文件,MDD4J作为插件同时被安装了。

xo#rVp%ZE0

T"I6W Ov%S0A0另外,也可以从IBM 技术支持站点http://www-306.ibm.com/software/support/isa/下载Support Assistant工具,然后选择更新程序,独立安装MDD4J插件。

rnK;]W)N|0W'L2f5x0

Hj k@ q+J+D @0启动步骤:51Testing软件测试网V.^,aB}

51Testing软件测试网F@/](mzb*zy

(1) 程序->IBM Support Assitant ->IBM Support Assistant v3

5f`d3z"U O.r?M0

)D-T%pUpu"Z0(2) 在Support Assistant窗口中,选择工具 -> 选择WebSphere版本号。51Testing软件测试网1Z-N:T$bA\4fc3bR)~1B;c

-E]'e6A&f d0点击MDD4J的链接,就可以开启MDD4J工具。在该界面中,我们可以提交单个heap dump文件进行单转储分析,或同时提交两个文件进行比较分析。也可以从内存转储分析结果的下拉选项中选择以前的分析结果,从而查看以前的分析内容。

;EpE:Q[0

7~%[#I/{&bm-~v0查看分析进度

*Sm2YfHG'e2S#d:g051Testing软件测试网K)cN`3s*P7LK

单击"上载并分析"按钮后,MDD4J开始分析heap dump文件。在分析执行过程中,登录页面将自动刷新,以反映当前正在执行的分析步骤以及整体分析进度。如果该页面由于某种原因而不刷新,您可以单击"刷新"按钮以了解当前分析状态。如果您希望停止分析,可以单击"停止"按钮,这将在当前正在执行的模块完成后终止分析。

}h|Px+rU ONi Q0

7L4@1Rwiy0在提交了heap dump文件,MDD4J显示分析状态。51Testing软件测试网3U0F8L Q"Gh{1i

51Testing软件测试网w9T0o6[\)Q ^o+_

查看分析结果51Testing软件测试网#bN] XW8{d/q9P`

&|Q8{3J+\R$i'O-OryL0分析完成后,Mdd4J页面将重定向到"分析结果"页面。"分析结果"页面包含 4 个选项卡:51Testing软件测试网U"j;gL"_^

51Testing软件测试网:U)f%Q@s"u

"分析总结"选项卡:显示分析结果总结,并列示下一组用于查看分析结果的步骤。

Z+Hf#eX?0

xW Fw c^ex0"可疑对象"选项卡:它显示四类可疑对象,即对增长幅度影响最大的数据结构、到达大小显著流失的数据结构、有大量实例的对象类型以及有大量对象实例的 Java 包。

s bx1}/BD*Mn\b1l3K051Testing软件测试网'|.emt@.N

"察看上下文和内容"选项卡:显示主内存转储中 Java 堆占用量的主要组成部分的拥有关系上下文图,以及图中所选节点的内容。51Testing软件测试网 U/o+Hi.X

51Testing软件测试网0P_ i(R'c\gRW"q

"浏览"选项卡:根据对对象引用图执行的深度优先遍历,用树形视图显示主内存转储的所有内容。51Testing软件测试网;~P^q@$h1z8n

m(KR%c@J8m~0其他内容,请参照MDD4J工具附带的Help文档,该帮助文档有详细的使用说明,在此不再赘述。51Testing软件测试网"^ V,yu7Te

51Testing软件测试网B:[\ x s4z$L#t+FI

7.小结

'E9vjpA\h051Testing软件测试网uB(S6o6w }

IBM提供了一系列的工具辅助用户进行内存问题的监控和分析,在合适的阶段选择合理的工具可以帮助我们轻松搞定内存泄漏。这里介绍的工具都是WebSphere附带或者免费的,IBM Tivoli工具还提供了更强大的监控和诊断功能,例如ITCAM (IBM Tivoli Composite Application Management),可以根据实际情况选用。51Testing软件测试网+OQg;c$|3Eu


TAG:

 

评分:0

我来说两句

Open Toolbar