环境: JDK 1.5/1.6, WebLogic 9.0 or later
当服务器挂起,崩溃或者性能很差时,可以抓取服务器的线程堆栈(Thread Dump)用于后续的分析.
Thread dump提供了当前活动的线程的快照. 它提供了JVM中所有Java线程的栈跟踪信息,有很多
方式可用于获取Thread Dump。
操作系统命令获取ThreadDump:
Windows:
a. 转向服务器的标准输出窗口并按下Control + Break组合键, 之后需要将线程堆栈复制到文件中
a. 转向服务器的标准输出窗口并按下Control + Break组合键, 之后需要将线程堆栈复制到文件中
UNIX/ Linux
首先查找到服务器的进程号(process id), 然后获取堆栈.
a. ps –ef | grep java
b. kill -3
-------------------------------------------
JVM 自带的工具获取线程堆栈:
JDK自带命令行工具获取PID并做ThreadDump:
a. jps
b. jstack
a. jps
b. jstack
使用JVisualVM:
Threads 标签页ThreadDump按钮.
Threads 标签页ThreadDump按钮.
-------------------------------------------
WebLogic 自带的获取 thread dump的工具:
1. 使用 Admin Console
a. 登录 Admin Console , 点击对应的服务器
b. 点击Server Monitoring Threads
c. 点击: Dump Thread Stack 按钮
a. 登录 Admin Console , 点击对应的服务器
b. 点击Server Monitoring Threads
c. 点击: Dump Thread Stack 按钮
2. 使用WLST (WebLogic Scripting Tool)
java weblogic.WLST
connect('weblogic','weblogic123','t3://dggtsebs01-vlx:7010')
cd('Servers')
cd('soa_server1')
threadDump()
disconnect()
exit()
注意: 线程堆栈将会保存在运行wlst的当前目录下.
来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/35489/viewspace-746641/,如需转载,请注明出处,否则将追究法律责任。
转载于:http://blog.itpub.net/35489/viewspace-746641/