百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT知识 > 正文

Java ThreadDump 生成解析

liuian 2025-04-27 14:43 55 浏览

当有我们的服务器CPU资源使用率(usr%)较高时,或者是一个基于 JAVA 的 Web 应用运行的比预期慢的时候,我们需要使用 Thread Dumps进行分析。线程转储是诊断CPU尖峰,死锁,响应时间差,内存问题,应用程序无响应以及其他系统问题的一项重要工作或者环节。

Thread Dump是非常有用的诊断Java应用问题的工具。每一个Java虚拟机都能够以不同的形式及时生成所有线程在某一点状态的Thread-Dump的能力,它能够给我们提供当前活动线程的快照,及JVM中所有Java线程的堆栈跟踪信息,堆栈信息一般包含完整的类名及所执行的方法。通常以文件的形式持久化到磁盘中

1、Jstack

Jstack是捕获线程转储的有效命令行工具。Jstack工具在$JAVA_HOME/bin目录中提供。此处为捕获线程转储所需发出的命令信号:

[administrator@JavaLangOutOfMemory luga ]% jstack -l <pid>> <文件路径>
pid:是应用程序的进程ID,应捕获其线程转储
file-path:是将写入线程转储的文件路径

具体地:

[administrator@JavaLangOutOfMemory luga ]% jstack -l 18790 > javacore.txt

按照如上示例执行,该过程的线程转储信息将在/data/logs/目录下以javacore.txt文本形式生成并进行展示。自Java 5以来,JDK中已包含Jstack工具。如果运行在旧版Java中,请考虑使用其他选项。

2、Kill

在大型企业中,出于安全原因,只有JRE安装在生产机器上。由于Jstack和其他工具只是JDK的一部分,因此有的时候无法使用Jstack工具。在这种情况下,可以使用“ kill -3”选项。

[administrator@JavaLangOutOfMemory luga ]% kill -3 <pid>
pid:是应用程序的进程ID,应捕获其线程转储

具体地:

[administrator@JavaLangOutOfMemory luga ]% kill -3 18790 

使用“ kill -3”选项时,线程转储将发送到标准错误流。如果我们在Tomcat Web容器中运行应用程序,则线程转储将发送到<TOMCAT_HOME> /logs/catalina.out文件中。

备注:目前,大多数* nix操作系统(Unix,Linux,HP-UX操作系统)都支持此选项。 其他操作系统暂未在生产环境实践。

3、Java VisualVM

Java VisualVM是一种图形用户界面工具,可在应用程序在指定的Java虚拟机(JVM)上运行时提供有关应用程序的详细信息。它位于$
JAVA_HOME/bin/jvisualvm.exe中。自JDK 6更新7.S起,它是Sun JDK发行版的一部分。

启动Jvisualvm。在左侧面板上,我们会注意到计算机上正在运行的所有Java应用程序。 我们需要从列表中选择所部署的应用程序。 除此之外,此工具还具有从远程主机上运行的java进程捕获线程转储的功能。


4、JMC

Java Mission Control(JMC)是一种工具,可以从本地运行或部署在生产环境中的Java应用程序收集和分析数据。自Oracle JDK 7 Update 40起,此工具已打包到JDK中。该工具还提供了从JVM进行线程转储的选项。位于$JAVA_HOME/bin/jmc.exe目录下。

启动该工具后,我们将看到本地主机上正在运行的所有Java进程。注意:JMC还可以与远程主机上运行的Java进程连接。现在,在左侧面板上,单击要进行线程转储的Java进程下方列出的“ Flight Recorder”选项。现在,我们将会看到“开始飞行记录”向导,如下图所示:

5、Jconsole

Jconsole是JDK自带的监控工具,在$JAVA_HOME/bin目录下可以找到。它用于连接正在运行的本地或者远程的JVM,对运行在java应用程序的资源消耗和性能进行监控,并画出大量的图表,提供强大的可视化界面。而且本身占用的服务器内存很小,甚至可以说几乎不消耗。

JConsole 是一个内置 Java 性能分析器,可以从命令行(直接输入jconsole)或在 GUI shell ($JAVA_HOME/bin下打开)中运行。它用于对JVM中内存,线程和类等的监控。可使用JTop插件。它可以监控本地的Jvm,也可以监控远程的Jvm,也可以同时监控几个Jvm。

这款工具的好处在于,占用系统资源少,而且结合Jstat,可以有效监控到java内存的变动情况,以及引起变动的原因。在项目追踪内存泄露问题时,很实用。

6、ThreadMXBean

从JDK 1.5开始,引入了ThreadMXBean。这是Java虚拟机中线程系统的管理接口。使用此接口,我们还可以生成线程转储。同时只需编写几行代码即可以编程方式生成线程转储。下面是ThreadMXBean实现的框架实现,该实现从应用程序生成Thread Dump。

public void  dumpThreadDump() {
        ThreadMXBean threadMxBean = ManagementFactory.getThreadMXBean();
        for (ThreadInfo ti : threadMxBean.dumpAllThreads(true, true)) {
            System.out.print(ti.toString());
        }
    }

7. APM工具– App Dynamics

很少有应用程序性能监视工具提供生成线程转储的选项。如果要通过App Dynamics(APM工具)监视应用程序,则以下是捕获线程转储的说明:

1、创建一个动作,在“创建动作”窗口中选择“诊断”->“执行线程转储”。

2、输入操作名称,要采样的数量以及线程转储之间的间隔(以毫秒为单位)。

3、如果要在启动线程转储操作之前需要批准,请选中“在此操作之前需要批准”复选框,然后输入被授权批准该操作的个人或组的电子邮件地址。有关更多信息,请参见需要批准的操作。

4、单击确定。

如下所示:

8、JCMD

Jcmd工具是随Oracle Java 7引入的。它对解决JVM应用程序的问题很有用。它具有各种功能,例如,识别Java进程ID,获取堆转储,获取线程转储,获取垃圾收集统计信息等。

[administrator@JavaLangOutOfMemory luga ]%jcmd <pid> Thread.print > <file-path>
pid:是应用程序的进程ID,应捕获其线程转储
file-path:是将写入线程转储的文件路径。

具体地:

[administrator@JavaLangOutOfMemory luga ]%jcmd  37300 Thread.print > /data/logs/threadDump.txt

- EOF -

如果您喜欢本文,欢迎点赞收藏留言,或者点击右下角,把文章分享给你的朋友们~~~

“路,在自己脚下~”

相关推荐

电脑硬盘数据恢复工具(电脑硬盘数据恢复多少钱一次)

只要是正版的数据恢复软件都会收费,如果想免费的话可以安装一个迷你兔数据恢复软件试试,因为它提供了200M的免费恢复额度,如果你的恢复需求不大,那就可以免费恢复

u盘有必要分区吗

分区好U盘分区的主要作用是将一个物理上的U盘分为多个逻辑上的独立区域,每个区域可以单独管理和使用。这样做的好处是可以将不同类型的文件分别存放在不同的分区中,提高文件的组织性和管理效率。例如,可以将工作...

优盘怎么做系统启动盘(优盘怎么做系统启动盘教程)

1/4分步阅读将U盘插上电脑,打开运行在电脑上下载好的小白一键重装系统软件,打开前退出所有杀毒软件,避免杀毒软件阻拦操作步骤。点击左侧“制作系统”,然后检测U盘后点击“开始制作”按钮。2/4在选择系统...

win7激活错误0 80072f8f(win7激活时发生错误,错误代码0x80072f8f)
win7激活错误0 80072f8f(win7激活时发生错误,错误代码0x80072f8f)

可以通过修改时间来解决系统提示0x80072F8F错误代码的操作方法。操作步骤1、鼠标点击时间,选择更改日期和时间设置,方法如下。2、在窗口中,选择internet时间,点击更改设置,方法如下。3、接着在窗口中,勾选与internet时间服...

2026-01-17 03:37 liuian

电脑如何进入bios模式(电脑怎么样进入bios)

电脑进入BIOS的方法1、按住F1电脑品牌:IBM、东芝、脸型thinkpad部分型号、toshiba等等这些型号电脑在开机时,按住键盘上的F1按键,那么它就会进入到BIOS的设置洁面中,需注意thi...

电脑如何设置虚拟内存(电脑怎么设虚拟内存怎么设最好)

进入系统打开控制面板后展开所有控制面板项,点击进入系统。修改虚拟内存点击高级系统设置后点击性能下的设置,点击高级后更改虚拟内存。设置数值将虚拟内存设置为自定义大小,具体数值最好是实际内存容量的一点五倍...

我的电脑图标打不开(电脑上图标消失了怎么恢复)

如果电脑点击图标没反应,首先看一下是不是鼠标左键的问题,左键出现故障图标往往是没有反应的,其次你把这些图标连一下,你看能不能画起来,如果无法划起来就是鼠标坏了,相反如果鼠标可以操作,但是电脑无法连接着...

联想y系列和r系列(联想7000)

联想y系列和r系列都好。其中r系列搭载的一般都是AMD锐龙处理器,y系列一般搭载的是英特尔处理器。希望我的回答对你有帮助一般情况下的话,联想笔记本电脑它的R系列和wy系列的画相比较来说是y系列,要稍微...

不激活win7有什么影响(不激活windows7会怎样)

如果Windows7未激活,会出现以下几种情况:1.桌面背景将变成黑色,每隔一段时间就会自动恢复成黑色。2.会弹出提示框,提醒用户需要激活Windows7。3.无法更新Windows,包括安...

超强升级系统 小说(超强升级系统 小说免费阅读)

女主柳洛溪,宋千千,肖甜甜,叶紫嫣,伏芸珊,南宫燕,菲菲,媛灵。狂暴系统的拥有者,龙家崛起的推动者,龙族守护者,天武大陆上屠魔者,新任远古界界王。前世为远古世界第一人,与远古世界一同孕育...

win11暂停更新点不了(win11设置永不更新)

win11更新不能暂停了是设置错误导致的,解决方法如下1、首先右键单击此电脑,选择管理。2、然后在中点击服务和应用程序。3、在弹出的列表中继续点击服务。4、在服务的右侧找到windowsupdate...

win10专业版下载速度慢(电脑win10下载速度慢)

由于是官方网址同时浏览该网址的网民非常多由于传输速率一定导致每个人的下载速率会变慢,可以错开高峰期如中午等,可以等到晚上或者早上期间进行下载。Win10系统浏览网页慢解决办法:1.在win10系统桌...

电脑关机总是关不掉(电脑关机一直关不掉怎么办)

电脑怎么关不了机是为什么电脑无法关机是因为还有软件在后台运行干预导致。鼠标右键点击计算机,选择属性,左侧菜单中选择高级系统设置,点击高级选项卡界面下方,启动和故障修复下的设置,取消勾选自动重新启动,点...

apple id是什么(appleID是什么意思)
apple id是什么(appleID是什么意思)

AppleID是苹果公司为其产品,如iWork、iTunesStore和AppleStore所引入的认证系统,使用Apple各项服务所需的用户名,就像是一把钥匙一样。有了AppleID,才能在苹果手机、平板电脑等设备上,使用苹...

2026-01-17 01:05 liuian

一键重装系统的软件有哪些(一键重装系统软件排行榜)

具体如下:一、韩博士装机大师韩博士装机大师是一款傻瓜式一键装系统工具,一键智能重装原版系统,无需光驱,无需U盘,零技术基础,傻瓜式操作,流水线流程,智能安装,完美支持GPT与win10平板!一款功能强...