如何抓取Thread Dump小结

 

作者: 刘长炯 BeanSoft@126.com 日期: 2011-11-28 本文环境: JDK 1.5/1.6, WebLogic 9.0 or later

当服务器挂起,崩溃或者性能底下时,就需要抓取服务器的线程堆栈(Thread Dump)用于后续的分析.

Thread dump提供了当前活动的线程的快照. 它提供了JVM中所有Java线程的栈跟踪信息

有很多方式可用于获取Thread Dump, 一些是操作系统特定的命令.

操作系统命令获取ThreadDump:

 

Windows:

1.      转向服务器的标准输出窗口并按下Control + Break组合键, 之后需要将线程堆栈复制到文件中

UNIX/ Linux

首先查找到服务器的进程号(process id), 然后获取堆栈.

1.      ps –ef  | grep java

2.      kill -3

 注意一定要谨慎, 一步不慎就可能让服务器进程被杀死!

 

JVM 自带的工具获取线程堆栈:

 

JDK自带命令行工具获取PID并做ThreadDump:

1.         jps

2.         jstack

使用JVisualVM:

Threads 标签页àThreadDump按钮.

WebLogic 自带的获取 thread dump的工具:

 

1. webLogic.Admin 工具

a. 打开命令提示符, 通过运行/bin/setDomain.env设置相关类路径

b. 执行下面的命令

java weblogic.Admin -url t3://localhost:7001 -username weblogic -password weblogic1 THREAD_DUMP

注意: Thread Dump 会打印到标准输出, nohup日志或者进程窗口.

2. 使用 Admin Console

a. 登录 Admin Console , 点击对应的服务器

b. 点击Server à Monitoring àThreads

c. 点击: Dump Thread Stack 按钮

3. 使用WLST (WebLogic Scripting Tool)

connect(‘weblogic’,’weblogic1’,’t3://localhost:7001’)

cd(‘Servers’)

cd(‘AdminServer’)

threadDump()

disconnect()

exit()

注意: 线程堆栈将会保存在运行wlst的当前目录下.

 

4. 使用utils.ThreadDumper

用法:

C:\bea\wlserver_10.3\server\lib>java -cp weblogic.jar utils.ThreadDumper

Broadcast Thread dumps disabled: must specify weblogic.debug.dumpThreadAddr and

weblogic.debug.dumpThreadPort

Exception in thread “main” java.lang.IllegalArgumentException: Port out of range

:-1

        at java.net.DatagramPacket.setPort(Unknown Source)

        at java.net.DatagramPacket.(Unknown Source)

        at java.net.DatagramPacket.(Unknown Source)

        at utils.ThreadDumper.sendDumpMsg(ThreadDumper.java:124)

        at utils.ThreadDumper.main(ThreadDumper.java:145)

5. 如果服务器是作为Windows服务的方式运行, 请运行下列命令:

%WL_HOME%\bin\beasvc -dump -svcname:service-name

其它一些获取Thread Dump的工具有jrcmd, jrmc(JRockit VM自带) ,Samurai, JProfiler, 还可通过JMX编程的方式获取, JDK自带示例代码:

$JAVA_HOME\demo\management\FullThreadDump

如何抓取Thread Dump小结 </p>

</b>

</p>

</b>

作者: 刘长炯 BeanSoft@126.com 日期: 2011-11-28 本文环境: JDK 1.5/1.6, WebLogic 9.0 or later </p>

</b>

</p>

</b>

当服务器挂起,崩溃或者性能底下时,就需要抓取服务器的线程堆栈(Thread Dump)用于后续的分析.

</p>

Thread dump提供了当前活动的线程的快照. 它提供了JVM中所有Java线程的栈跟踪信息

</p>

有很多方式可用于获取Thread Dump, 一些是操作系统特定的命令.

</p>

</p>

操作系统命令获取ThreadDump: </p>

</b>

</p>

Windows:

</p>

1.      转向服务器的标准输出窗口并按下Control + Break组合键, 之后需要将线程堆栈复制到文件中

</p>

UNIX/ Linux

</p>

首先查找到服务器的进程号(process id), 然后获取堆栈.

</p>

1.      ps –ef  | grep java

</p>

2.      kill -3 </span> </p></p>

 注意一定要谨慎, 一步不慎就可能让服务器进程被杀死! </p>

</span>

</p>

JVM 自带的工具获取线程堆栈: </p>

</b>

JDK自带命令行工具获取PID并做ThreadDump:

</p>

1.<span style="font:7pt "">         </span>jps

</p>

2.<span style="font:7pt "">         </span>jstack </span> </p></p>

使用JVisualVM:

</p>

Threads 标签页àThreadDump按钮.

</p>

</p>

WebLogic 自带的获取 thread dump的工具: </p>

</b>

1. webLogic.Admin 工具

</p>

a. 打开命令提示符, 通过运行/bin/setDomain.env</span>设置相关类路径 </p></p>

b. 执行下面的命令

</p>

java weblogic.Admin -url t3://localhost:7001 -username weblogic -password weblogic1 THREAD_DUMP

</p>

注意: Thread Dump 会打印到标准输出, nohup日志或者进程窗口.

</p>

2. 使用 Admin Console

</p>

a. 登录 Admin Console , 点击对应的服务器

</p>

b. 点击Server à Monitoring àThreads

</p>

c. 点击: Dump Thread Stack 按钮

</p>

3. 使用WLST (WebLogic Scripting Tool)

</p>

connect(‘weblogic’,’weblogic1’,’t3://localhost:7001’)

</p>

cd(‘Servers’)

</p>

cd(‘AdminServer’)

</p>

threadDump()

</p>

disconnect()

</p>

exit()

</p>

注意: 线程堆栈将会保存在运行wlst的当前目录下.

</p>

 

</p>

4. 使用utils.ThreadDumper

</p>

用法:

</p>

C:beawlserver_10.3serverlib>java -cp weblogic.jar utils.ThreadDumper

</p>

Broadcast Thread dumps disabled: must specify weblogic.debug.dumpThreadAddr and

</p>

weblogic.debug.dumpThreadPort

</p>

Exception in thread “main” java.lang.IllegalArgumentException: Port out of range

</p>

:-1

</p>

        at java.net.DatagramPacket.setPort(Unknown Source)

</p>

        at java.net.DatagramPacket.(Unknown Source)</span> </p></p>

        at java.net.DatagramPacket.(Unknown Source)</span> </p></p>

        at utils.ThreadDumper.sendDumpMsg(ThreadDumper.java:124)

</p>

        at utils.ThreadDumper.main(ThreadDumper.java:145)

</p>

</p>

5. 如果服务器是作为Windows服务的方式运行, 请运行下列命令:

</p>

WL_HOMEbinbeasvc -dump -svcname:service-name

</p>

</p>

其它一些获取Thread Dump的工具有jrcmd, jrmc(JRockit VM自带) ,Samurai, JProfiler, 还可通过JMX编程的方式获取, JDK自带示例代码:

</p>

$JAVA_HOMEdemomanagementFullThreadDump

</p>

</p>

转载请注明:WebLogic Android 博客 » 如何抓取Thread Dump小结