Java 中怎么获取一份线程 dump 文件

Java 中怎么获取一份线程 dump 文件,第1张

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

2jstack <pid>

使用JVisualVM:

Threads 标签页 →ThreadDump按钮

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

1 webLogicAdmin 工具

a 打开命令提示符, 通过运行<DOMAIN_HOME>/bin/setDomainenv设置相关类路径

b 执行下面的命令

java weblogicAdmin -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 使用utilsThreadDumper

用法:

C:\bea\wlserver_103\server\lib>java -cp weblogicjar utilsThreadDumper

Broadcast Thread dumps disabled: must specify weblogicdebugdumpThreadAddr and

weblogicdebugdumpThreadPort

Exception in thread "main" javalangIllegalArgumentException: Port out of range

:-1

at javanetDatagramPacketsetPort(Unknown Source)

at javanetDatagramPacket<init>(Unknown Source)

at javanetDatagramPacket<init>(Unknown Source)

at utilsThreadDumpersendDumpMsg(ThreadDumperjava:124)

at utilsThreadDumpermain(ThreadDumperjava: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)用于后续的分析

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 webLogicAdmin 工具

a 打开命令提示符, 通过运行<DOMAIN_HOME>/bin/setDomainenv设置相关类路径

b 执行下面的命令

java weblogicAdmin -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 使用utilsThreadDumper

用法:

C:\bea\wlserver_103\server\lib>java -cp weblogicjar utilsThreadDumper

Broadcast Thread dumps disabled: must specify weblogicdebugdumpThreadAddr and

weblogicdebugdumpThreadPort

Exception in thread "main" javalangIllegalArgumentException: Port out of range

:-1

at javanetDatagramPacketsetPort(Unknown Source)

at javanetDatagramPacket<init>(Unknown Source)

at javanetDatagramPacket<init>(Unknown Source)

at utilsThreadDumpersendDumpMsg(ThreadDumperjava:124)

at utilsThreadDumpermain(ThreadDumperjava: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介绍

11什么是Thread Dump?

Thread Dump是非常有用的诊断Java应用问题的工具。每一个Java虚拟机都有及时生成所有线程在某一点状态的thread-dump的能力,虽然各个 Java虚拟机打印的thread dump略有不同,但是大多都提供了当前活动线程的快照,及JVM中所有Java线程的堆栈跟踪信息,堆栈信息一般包含完整的类名及所执行的方法,如果可能的话还有源代码的行数。

12 Thread Dump特点

1 能在各种 *** 作系统下使用

2 能在各种Java应用服务器下使用

3 可以在生产环境下使用而不影响系统的性能

4 可以将问题直接定位到应用程序的代码行上

13 Thread Dump 能诊断的问题

1 查找内存泄露,常见的是程序里load大量的数据到缓存;

2 发现死锁线程;

14如何抓取Thread Dump

一般当服务器挂起,崩溃或者性能底下时,就需要抓取服务器的线程堆栈(Thread Dump)用于后续的分析 在实际运行中,往往一次 dump的信息,还不足以确认问题。为了反映线程状态的动态变化,需要接连多次做threaddump,每次间隔10-20s,建议至少产生三次 dump信息,如果每次 dump都指向同一个问题,我们才确定问题的典型性。

有很多方式可用于获取ThreadDump, 下面列出一部分获取方式:

*** 作系统命令获取ThreadDump:

Windows:

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

UNIX/ Linux:

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

1 ps –ef | grep java

2 kill -3 <pid>

注意:一定要谨慎, 一步不慎就可能让服务器进程被杀死。kill -9 命令会杀死进程。

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

JDK自带命令行工具获取PID,再获取ThreadDump:

1 jps 或 ps –ef|grepjava (获取PID)

2 jstack [-l ]<pid> | tee -a jstacklog (获取ThreadDump)

二、java线程的状态转换介绍(为后续分析做准备)

21 新建状态(New)

用new语句创建的线程处于新建状态,此时它和其他Java对象一样,仅仅在堆区中被分配了内存。

22 就绪状态(Runnable)

当一个线程对象创建后,其他线程调用它的start()方法,该线程就进入就绪状态,Java虚拟机会为它创建方法调用栈和程序计数器。处于这个状态的线程位于可运行池中,等待获得CPU的使用权。

23 运行状态(Running)

处于这个状态的线程占用CPU,执行程序代码。只有处于就绪状态的线程才有机会转到运行状态。

24 阻塞状态(Blocked)

阻塞状态是指线程因为某些原因放弃CPU,暂时停止运行。当线程处于阻塞状态时,Java虚拟机不会给线程分配CPU。直到线程重新进入就绪状态,它才有机会转到运行状态。

阻塞状态可分为以下3种:

1)位于对象等待池中的阻塞状态(Blocked in object’s wait pool):当线程处于运行状态时,如果执行了某个对象的wait()方法,Java虚拟机就会把线程放到这个对象的等待池中,这涉及到“线程通信”的内容。

2)位于对象锁池中的阻塞状态(Blocked in object’s lock pool):当线程处于运行状态时,试图获得某个对象的同步锁时,如果该对象的同步锁已经被其他线程占用,Java虚拟机就会把这个线程放到这个对象的锁池中,这涉及到“线程同步”的内容。

当服务器挂起,崩溃或者性能底下时,就需要抓取服务器的线程堆栈(Thread Dump)用于后续的分析Thread dump提供了当前活动的线程的快照 它提供了JVM中所有Java线程的栈跟踪信息有很多方式可用于获取Thread Dump, 一些是 *** 作系统特定的命令 *** 作系统命令获取ThreadDump: Windows:1 转向服务器的标准输出窗口并按下Control + Break组合键, 之后需要将线程堆栈复制到文件中UNIX/ Linux首先查找到服务器的进程号(process id), 然后获取堆栈1 ps –ef | grep java2 kill -3 注意一定要谨慎, 一步不慎就可能让服务器进程被杀死! JVM 自带的工具获取线程堆栈:JDK自带命令行工具获取PID并做ThreadDump:1 jps2 jstack 使用JVisualVM:Threads 标签页àThreadDump按钮 WebLogic 自带的获取 thread dump的工具:1 webLogicAdmin 工具a 打开命令提示符, 通过运行/bin/setDomainenv设置相关类路径b 执行下面的命令java weblogicAdmin -url t3://localhost:7001 -username weblogic -password weblogic1 THREAD_DUMP注意: Thread Dump 会打印到标准输出, 如nohup日志或者进程窗口2 使用 Admin Consolea 登录 Admin Console , 点击对应的服务器b 点击Server à Monitoring àThreadsc 点击: Dump Thread Stack 按钮3 使用WLST (WebLogic Scripting Tool)connect(‘weblogic’,'weblogic1’,’t3://localhost:7001’)cd(‘Servers’)cd(‘AdminServer’)threadDump()disconnect()exit()注意: 线程堆栈将会保存在运行wlst的当前目录下 4 使用utilsThreadDumper用法:C:\bea\wlserver_103\server\lib>java -cp weblogicjar utilsThreadDumperBroadcast Thread dumps disabled: must specify weblogicdebugdumpThreadAddr andweblogicdebugdumpThreadPortException in thread "main" javalangIllegalArgumentException: Port out of range:-1 at javanetDatagramPacketsetPort(Unknown Source) at javanetDatagramPacket(Unknown Source) at javanetDatagramPacket(Unknown Source) at utilsThreadDumpersendDumpMsg(ThreadDumperjava:124) at utilsThreadDumpermain(ThreadDumperjava: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

其中jmap是java自带的工具查看整个JVM内存状态jmap-heap[pid]要注意的是在使用CMSGC情况下,jmap-heap的执行有可能会导致JAVA进程挂起查看JVM堆中对象详细占用情况jmap-histo[pid]导出整个JVM中内存信息jmap-dump:format=b,file=文件名[pid]jhat是sun16及以上版本中自带的一个用于分析JVM堆DUMP文件的工具,基于此工具可分析JVMHEAP中对象的内存占用情况jhat-J-Xmx1024M[file]执行后等待console中输入start>

以上就是关于Java 中怎么获取一份线程 dump 文件全部的内容,包括:Java 中怎么获取一份线程 dump 文件、如何抓取Thread Dump小结、如何分析java Thread DUMP等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/web/9338203.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-04-27
下一篇2023-04-27

发表评论

登录后才能评论

评论列表(0条)

    保存