如何抓取Thread Dump小结

当服务器挂起,崩溃或者性能底下时,就需要抓取服务器的线程堆栈(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 <pid>

 

 

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

 

 

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

 

 

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

 

 

1.         jps

 

 

2.         jstack <pid>

 

 

使用JVisualVM:

 

 

Threads 标签页àThreadDump按钮.

 

 

 

 

 

 

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

 

 

1. webLogic.Admin 工具

 

 

a. 打开命令提示符通过运行<DOMAIN_HOME>/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.<init>(Unknown Source)

 

 

        at java.net.DatagramPacket.<init>(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

猜你喜欢

转载自andyaqu.iteye.com/blog/2037447