Java ThreadDump 生成解析
qihemm 2025-06-13 09:30 7 浏览 0 评论
当有我们的服务器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 -
如果您喜欢本文,欢迎点赞、收藏、留言,或者点击右下角,把文章分享给你的朋友们~~~
“路,在自己脚下~”
相关推荐
- VLOOKUP的18种高阶用法大公开!99%的人都不知道的神操作!
-
作为被头条用户催更的Excel课代表,今天带来让HR追着要模板、让老板主动加薪的VLOOKUP终极指南!从基础到高阶一网打尽,文末送36个行业专用模板!一、为什么你的VLOOKUP总报错?血泪大数据...
- Vlooup公式,2种模糊查找匹配,1分钟学会
-
工作中,VLOOKUP公式使用频率是很高的,用来各种查找匹配问题今天我们分享两种模糊查找匹配问题,一种是文本的模糊查找匹配,一种是数字的模糊查找匹配问题1、文本模糊查找匹配使用模拟数据举个例子,原始数...
- 与vlookup功能相似的函数,照样搞定表格数据查询,简单还实用
-
在日常表格数据处理工作,说到数据查询,很多小伙伴首先想到的是Vlookup函数,老师的教程中也多次讲到Vlookup函数的用法和实例。其实在Excel中还有其他的数据查询函数公式或技巧,今天我们先来学...
- 别再折腾VLOOKUP了!DGET逆向查找10秒通关,小白必看
-
今天要掀翻一个“过气网红”——VLOOKUP!你是不是也经历过这些崩溃瞬间:逆向查找要交换列顺序,复制粘贴到手软!多条件查找要嵌套MATCH,公式长到怀疑人生!别忍了!今天教你用DGET函数一键封...
- 职场新人必学!VLOOKUP函数10分钟速成指南
-
正文:"今天来讲解办公人入职期初函数VLOOKUP,这是所有职场人最重要也是最基础的技能。掌握它,90%的数据查找再不用求人!特别献给刚入职场的你——别让Excel成为加班理由。"——...
- 巧用Vlookup函数揪出“第三者”(vlookup第三个参数是什么)
-
在一张Excel表格的重复记录中,让你快速列出每种不同物品第2次或第n次出现的记录,你会怎么做?Vlookup函数就有这个本事。举例来说,产品或者物流表格中往往会记录有同一货物的多笔数据(如下图的今日...
- 分享12个VLOOKUP超经典用法(vlookup通俗易懂)
-
刚毕业那会,面试的时候经常会被问到会不会用Excel?我就理直气壮地回答:“会啊。”毕竟,简历上可是写着熟练。接着面试官扔出一句“那你会VLOOKUP吗?”我还是会一口咬定:“我会。“其实,我都没用过...
- 查找匹配别只知道Vlookup,Sumifs也可以!
-
工作中遇到查找匹配问题的时候,大家第一反应是不是都想到的Vlookup公式呢,有没有小伙伴们给Sumifs一点点机会的呢,有时候Sumifs比Vlookup更好用1、Vlookup公式举个例子,左边是...
- Excel函数讲解:VLOOKUP函数,轻松玩转数据查找
-
常用函数系列教学:VLOOKUP函数讲解(46)。不懂VLOOKUP函数怎么高效查找数据?闲话少叙直接开讲。基本含义:VLOOKUP函数用于在表格按垂直方向(到)上查找返回行数据。如何使用及注意事项?...
- CHOOSEROWS+CHOOSECOLS原来是一个超级查找函数组合!
-
场景一:要在学生名册中,抽查一名学生成绩。公式:=CHOOSEROWS(A1:D5,2)解析:第一参数A1:D5为数据区域,第二参数2表示提取第2行数据。把数据区域改为A2:D5,结合RANDBETW...
- 数据查询不止有vlookup函数,自定义zlookup函数查询操作更高效
-
Excel数据查询,相信大家首先会想到vlookup函数。毋庸置疑vlookup函数在Excel数据查询中作用是非常的强大。但是它也有一些不能实现的数据查询。如上图所示,我们需要根据人员的出现次数,提...
- 「EXCEL进阶」VLOOKUP函数怎么查询一个值返回多个结果
-
前言:VLOOKUP函数一般一次只能返回一个结果,本例介绍通过辅助列的方法使VLOOKUP函数查询一个值,返回这个值对应的多个结果。使用场景举例:根据表格中同一数值,返回对应值的多个结果。比如这张数据...
- WPS查找能手VLOOKUP函数使用方法讲解
-
各位同学好!今天我们来深度剖析WPS最实用的查找工具——VLOOKUP函数。这个函数能帮你在表格中快速定位并提取所需数据,可以帮你快速核对两批数据差异,还可以合并多个表格的关联信息,甚至可以帮你制作动...
- Excel常用10个函数:跨表查找Vlookup,适用于大数据中查找精确值
-
Hello大家好,我是Office米,今天,我们将和大家一起分享交流,常用的10个函数之一:查找引用函数VLOOKUP。在说VLOOKUP函数之前,我们要先了解,平时Excel日常工作中会遇到哪些问题...
- 掌握了这个套路,无论用 Excel vlookup 函数查找第几次结果都很轻松
-
用vlookup查找默认情况下是一对一出结果,如果要一对多查找,就需要用到各种技巧,具体方法我写过非常多了,可以搜索一下历史记录。只要掌握了今天这个套路,无论你想查找第几次重复值,都易如反掌。案例...
你 发表评论:
欢迎- 一周热门
- 最近发表
-
- VLOOKUP的18种高阶用法大公开!99%的人都不知道的神操作!
- Vlooup公式,2种模糊查找匹配,1分钟学会
- 与vlookup功能相似的函数,照样搞定表格数据查询,简单还实用
- 别再折腾VLOOKUP了!DGET逆向查找10秒通关,小白必看
- 职场新人必学!VLOOKUP函数10分钟速成指南
- 巧用Vlookup函数揪出“第三者”(vlookup第三个参数是什么)
- 分享12个VLOOKUP超经典用法(vlookup通俗易懂)
- 查找匹配别只知道Vlookup,Sumifs也可以!
- Excel函数讲解:VLOOKUP函数,轻松玩转数据查找
- CHOOSEROWS+CHOOSECOLS原来是一个超级查找函数组合!
- 标签列表
-
- 正版织梦模板 (30)
- 单片机c语言入门基础知识 (32)
- 手机编程游戏 (29)
- 优秀企业网站模板 (34)
- python编程入门自学书籍 (34)
- phpcms安装 (30)
- 自学excel免费视频教程全集 (36)
- php加密系统源码 (29)
- vlookup函数查找 (30)
- 电脑怎么下载java (32)
- vba编程实例速成150例 (30)
- 函数subtotal的用法 (31)
- java教程txt (32)
- java软件开发面试题 (30)
- sql数据库备份与还原方法 (33)
- 后台管理系统网站模板 (30)
- html表单属性有哪些 (31)
- 初中数学三角函数公式 (32)
- python爬虫教程 (30)
- 三角函数值对照表0到360度 (33)
- oracle数据库下载教程 (31)
- index函数什么意思 (34)
- indirect函数的详细用法 (31)
- excel函数round用法 (32)
- vlookup一对多查询并提取 (35)