Thinking in Mobile

学海无涯乐作舟

  BlogJava :: 首页 :: 联系 :: 聚合  :: 管理
  0 Posts :: 26 Stories :: 1 Comments :: 0 Trackbacks

生成Heap dump文件

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

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

我们在任何时候,可以随时手动生成所需的heap dump文件。在WAS6.1 profile的bin目录下,首先运行wsadmin 脚本客户端,然后可以调用generateHeapDump操作来完成。

关键步骤:

1. 找到JVM对象名字。

<wsadmin> set objectName
            WebSphere:type=JVM,process=<WebSphere服务器名字>,node=<节点名字>,*]

2. 对JVM MBean调用generateHeapDump操作。

<wsadmin> $AdminControl invoke $objectName generateHeapDump

例如:
[root@csspvm bin]# pwd
            /opt/IBM/WebSphere/WAS6.1/profiles/AppSrv01/bin
            [root@csspvm bin]# ./wsadmin.sh -username root -password demo4you
            WASX7209I: Connected to process "server1" on node csspvmNode02 using SOAP
            connector;  The type of process is: UnManagedProcess
            WASX8011W: AdminTask object is not available.
            WASX7029I: For help, enter: "$Help help"
            wsadmin>set objectName [$AdminControl queryNames
            WebSphere:type=JVM,process=server1, node=csspvmNode02,*]
            WebSphere:name=JVM,process=server1,platform=proxy,node=csspvmNode02,
            j2eeType=JVM,J2EEServer=server1,
            version=6.1.0.0,type=JVM,mbeanIdentifier=JVM,cell=csspvmNode02Cell,spec=1.0
            wsadmin>$AdminControl invoke $ objectName generateHeapDump
            /opt/IBM/WebSphere/WAS6.1/profiles/AppSrv01/./heapdump.20060904.075650.3576.phd
            wsadmin>quit

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

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

posted on 2010-01-03 00:24 W.Y.H 阅读(3509) 评论(0)  编辑  收藏 所属分类: WAS

只有注册用户登录后才能发表评论。


网站导航: