websphere性能调优之dump命令

基于WebSphere 构建的企业应用,时常会出现性能问题,在严重的情况下还会提示出内存溢出,这是一件很让人恼怒的事情。在WebSphere Application Server(Was)运行的时候,内存溢出,会生成大量的溢出文件,如Javacore, Heapdump等文件,占用了大量的磁盘空间。在这种情况下,时常会出现一连串的系统问题,如部署在Was的所有应用服务都报错,Was连控制台也无法访问等。

为解决问题,我们通常会选择重新启动整个Was或者服务器,然后分析运行日志SystemOut.log、ystemErr.log、ative_stdout.log、native_stderr.log 和系统内存溢出的时候产生的Javacore、Heapdump文件来寻找出问题。

如果我们在测试中发现系统运行一段时间后响应开始缓慢,但Was又没有挂掉时,就可以通过人工操作产生JavaCore、Heapdump等文件,通过对相关文件、日志的分析来查找系统是否存在内存溢出的隐患。

下面介绍一下产生JavaCore、Heapdump文件的方法——websphere的dump命令。

一、Linux平台

大致步骤:

1)进入WAS安装目录的bin目录,如果是WAS6.0, 请进入所在profile的bin目录;

2)执行wsadmin.sh进入WSADMIN命令行方式提示符会变成wsadmin>

3) 执行以下命令:(注意将server1改为你的server的名字,两个逗号之间没空格)

a) 设置jvm环境变量:

wsadmin> set jvm [$AdminControl queryNames type=JVM,process=server1,*] 

b) 生成javacore文件:

wsadmin> $AdminControl invoke $jvm dumpThreads

c) 退出WSADMIN命令行:

wsadmin> quit

执行完后将在was安装目录或所在profile的目录下产生JavaCore文件,通过分析JavaCore以及相关的SystemOut,SystemErr和nativestd_err等文件可以得知系统gc是否正常,是否存在有内存溢出的情况。

具体操作:

--进入bin目录

[[email protected] bin]# pwd     

/opt/IBM/WebSphere/WAS6.1/profiles/AppSrv01/bin

--进入WSADMIN命令行方式

[[email protected] bin]# ./wsadmin.sh -username root -password root  

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"

--设置jvm环境变量

wsadmin>set objectName [$AdminControl queryNames WebSphere:type=JVM,process=server1, node=webNode01,*]    

WebSphere:name=JVM,process=server1,platform=proxy,node=csspvmNode02,j2eeType=JVM,J2EEServer=server1,version=6.1.0.0,type=JVM,mbeanIdentifier=JVM,cell=webNode01Cell,spec=1.0

  

--生成heapdump文件

wsadmin>$AdminControl invoke $objectName generateHeapDump     

/opt/IBM/WebSphere/WAS6.1/profiles/AppSrv01/./heapdump.20100904.075650.3576.phd

wsadmin>set jvm [$AdminControl queryNames WebSphere:type=JVM,process=server1,node=webNode01,*]

  

--生成JavaCore文件

wsadmin>$AdminControl invoke $jvm dumpThreads

wsadmin>quit

--"webNode01"为websphere节点名称。

取线程:JavaCore

set objectName [$AdminControl queryNames WebSphere:type=JVM,process=server1,node=webNode01,*]

set jvm [$AdminControl queryNames WebSphere:type=JVM,process=server1,node=webNode01,*]

$AdminControl invoke $objectName dumpThreads

$AdminControl invoke $jvm dumpThreads

  

取堆栈:heapdump

wsadmin -user admin -password zxin10 -c "$AdminControl invoke [$AdminControl queryNames WebSphere:type=JVM,process=server1,node=webNode01,*] generateHeapDump"

$AdminControl invoke $jvm generateHeapDump

$AdminControl invoke [$AdminControl queryNames WebSphere:type=JVM,process=server1,node=webNode01,*] generateHeapDump

  

二、 Windows平台

在Windows 下,生成JavaCore与HeapDump的方式比较简单。

1 使用Ctrl+Break

如果WebSphere是在命令行窗口启动,有启动命令行窗口,那么可以通过在命令行窗口中使用Ctrl+Break键,产生JavaCore和HeapDump。

2 调用程序

IBM 的JDK提供了接口,通过调用这个接口,可以直接生成JavaCore以及 HeapDump。

生成JavaCore:

调用JSP文件,jsp中只有一行语句,如下所示

<%
com.ibm.jvm.Dump.JavaDump();
%>

生成HeapDump

调用JSP文件,jsp中只有一行语句,如下所示

<%
com.ibm.jvm.Dump.HeapDump();
%>

调用方法后将在was安装目录或所在profile的目录下产生相关JavaCore、Heapdump文件。

好了,到这里大家学会了如何产生JavaCore、Heapdump文件,问题又来了:怎么分析产生的JavaCore、Heapdump文件呢?后面会为大家继续分享”JavaCore、Heapdump文件分析方法”。

时间: 2025-01-06 18:55:00

websphere性能调优之dump命令的相关文章

基于Linux的WebSphere性能调优与故障诊断

一.关于was数据源等问题的配置 (1)关于was数据源连接池的最大.最小配置多大合适?怎样去计算? (2)关于JVM的配置,64位系统,64位WAS,最值小和最大配置多大最优?怎样去计算? (3)应用服务器线程池,怎么样配置最优? 怎样去计算? (4)linux上安装was完成后,linux必须配置哪些参数,was性能最优?如果不配置的话,性能影响大吗 数据库连接池建议初始化调优10-100.was连接池参数说明及调优V1.0:http://www.webspherechina.net/Doc

(转)JVM性能调优之生成堆的dump文件

转自:http://blog.csdn.net/lifuxiangcaohui/article/details/37992725 最近因项目存在内存泄漏,故进行大规模的JVM性能调优 , 现把经验做一记录. 一.JVM内存模型及垃圾收集算法 1.根据Java虚拟机规范,JVM将内存划分为: New(年轻代) Tenured(年老代) 永久代(Perm) 其中New和Tenured属于堆内存,堆内存会从JVM启动参数(-Xmx:3G)指定的内存中分配,Perm不属于堆内存,有虚拟机直接分配,但可以

盘点linux系统中的12条性能调优命令。

导读 性能调优一直是运维工程师最重要的工作之一,如果您所在的生产环境中遇到了系统响应速度慢,硬盘IO吞吐量异常,数据处理速度低于预期值的情况,又或者如CPU.内存.硬盘.网络等系统资源长期处于耗尽的状态,那么这篇文章将着实的能帮助到你,如果没有也请先收藏起来. 1,hdparm查看硬度读取速度: 命令:hdparm -t /dev/sda5 打印:Timing buffered disk reads: 254 MB in 3.01 seconds = 84.34 MB/sec 说明:能够指定具体

JVM常用命令和性能调优建议

一.查看jvm常用命令jinfo:可以输出并修改运行时的java 进程的opts. jps:与unix上的ps类似,用来显示本地的java进程,可以查看本地运行着几个java程序,并显示他们的进程号. jstat:一个极强的监视VM内存工具.可以用来监视VM内存内的各种堆和非堆的大小及其内存使用量. jmap:打印出某个java进程(使用pid)内存内的所有'对象'的情况(如:产生那些对象,及其数量). jconsole:一个java GUI监视工具,可以以图表化的形式显示各种数据.并可通过远程

详解性能调优命令

1.ps 通常我们会使用ps -aux查看用户启动的进程 USER:进程的属主 PID:进程的ID %CPU:进程占CPU的百分比 %MEM:进程占内存的百分比 VSZ:进程使用的虚拟内存量(KB) RSS:进程使用的固定内存量(KB) TTY:进程运行的终端,若与终端无关,则显示?.若为pts/0等,则表示由网络连接主机进程 STAT:进程的状态 D:不可中断的静止 R:正在执行中 S:静止状态 T:暂停静止 Z:不存在但暂时无法消除 W:没有足够的记忆体分页可分配 <:高优先序的行程 N:低

JVM性能调优监控工具jps、jstack、jmap、jhat、jstat、hprof使用详解

现实企业级Java开发中,有时候我们会碰到下面这些问题: OutOfMemoryError,内存不足 内存泄露 线程死锁 锁争用(Lock Contention) Java进程消耗CPU过高 ...... 这些问题在日常开发中可能被很多人忽视(比如有的人遇到上面的问题只是重启服务器或者调大内存,而不会深究问题根源),但能够理解并解决这些问题是Java程序员进阶的必备要求.本文将对一些常用的JVM性能调优监控工具进行介绍,希望能起抛砖引玉之用.本文参考了网上很多资料,难以一一列举,在此对这些资料的

[转]JVM性能调优监控工具

http://my.oschina.net/feichexia/blog/196575?p=1#comments JDK本身提供了很多方便的JVM性能调优监控工具,除了集成式的VisualVM和jConsole外,还有jps.jstack.jmap.jhat.jstat.hprof等小巧的工具,本博客希望能起抛砖引玉之用,让大家能开始对JVM性能调优的常用工具有所了解. 现实企业级Java开发中,有时候我们会碰到下面这些问题: OutOfMemoryError,内存不足 内存泄露 线程死锁 锁争

性能调优工具

[性能调优工具jps.jstack.jmap.jhat.jstat.hprof使用详解]http://my.oschina.net/feichexia/blog/196575 现实企业级Java开发中,有时候我们会碰到下面这些问题: OutOfMemoryError,内存不足 内存泄露 线程死锁 锁争用(Lock Contention) Java进程消耗CPU过高 这些问题在日常开发中可能被很多人忽视(比如有的人遇到上面的问题只是重启服务器或者调大内存,而不会深究问题根源),但能够理解并解决这些

Java内存泄露及性能调优

内存泄漏及解决方法 1.系统崩溃前的一些现象:每次垃圾回收的时间越来越长,由之前的10ms延长到50ms左右,FullGC的时间也有之前的0.5s延长到4.5sFullGC的次数越来越多,最频繁时隔不到1分钟就进行一次FullGC年老代的内存越来越大并且每次FullGC后年老代没有内存被释放 之后系统会无法响应新的请求,逐渐到达OutOfMemoryError的临界值. 2.生成堆的dump文件 通过JMX的MBean生成当前的Heap信息,大小为一个3G(整个堆的大小)的hprof文件,如果没