【Linux篇】jstack命令简介

jatack命令简介

jstack 命令是JDK工具之一,使用该命令可以打印正在运行中 Java 进程的栈信息。

1. 帮助文档

[root@jiangnan ~]# jstack --help
Usage:
    jstack [-l] <pid>
        (to connect to running process)
    jstack -F [-m] [-l] <pid>
        (to connect to a hung process)
    jstack [-m] [-l] <executable> <core>
        (to connect to a core file)
    jstack [-m] [-l] [server_id@]<remote server IP or hostname>
        (to connect to a remote debug server)

Options:
    -F  to force a thread dump. Use when jstack <pid> does not respond (process is hung)(强制打印线程栈信息,在jstack <pid>命令没有响应的时候添加该选项可以实现强制打印)
    -m  to print both java and native frames (mixed mode)((mix)混合模式,可以打印 Java 栈和本地方法栈)
    -l  long listing. Prints additional information about locks((long listing)长列表模式. 额外打印关于锁的信息)
    -h or -help to print this help message
[root@jiangnan ~]# 

2. jstack用法

首先使用 jps命令查看需要打印线程栈的java进程号。

[sams@sams-app-app-7758c59fcd-dh84t ~]$ jps 
82 ASMain
17037 Jps 
[sams@sams-app-app-7758c59fcd-dh84t ~]

我们这里链接到 82 这个进程号上,使用下面命令:

[sams@sams-app-app-7758c59fcd-dh84t ~]$ jstack 82
2022-85-08 13:49:28
Full thread dump OpenJDK 64-Bit Server VM (25.265-B01 mixed mode):

"Attach Listener" #243 daemon prio=9 os_ prio=8 tid-8x00087f688001888 nid=8x1e8 waiting on condition [8x8088888088888 ] 
	java.lang.Thread.State: RUNNABLE

"WG- TxProcessor-worker-2" #241 daemon prio=5 os_ prio=8 tid-0x88887f6ddc88b088 nid=8x1e6 waiting on condition [8x88887f6d26fc5088] 
java.lang.Thread.State: WAITING (parking)
at sun.misc Unsafe·park(Native Method)

- parking to wait for <x0808087236d4d50 (a java.util.concurrent.locks.AbstractQueuedSynchronizer$Conditionbc 
at java.util.concurrent.locks.LockSupport.park(LockSupport.java:175)

at java. util. concurrent.locks.AbstractQueuedSynchronizer$Condition . await(AbstractQueuedSynchone.java: 2839) at java.util.concurrent.LinkedBlockingQueue.take(LinkedBlockingQueue. java:442)
at java.util.concurrent.ThreadPoolExecutor.getTask(ThreadPoolExecutor.java:1874)
at java.util.concurrent.ThreadPoolExecutor.runlorker(ThreadPoolExecuto.java:1134)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java 624)
at java.lang.Thread.run(Thread.java:748)

可以看到控制台打印出了线程的信息以及线程对应的堆栈信息。

java.lang.Thread.State: RUNNABLE 线程状态

在这里插入图片描述

我们通过 jstack查看线程栈信息时通常看到的最多的是RUNNABLE,BLOCKED,WAITINGTIMED_WAITING这几种状态,我们一般看不到线程的NEWTERMINATED状态,是因为在代码的运行过程中这两种状态只占很小一部分,我们捕捉到这两种状态前这两种状态已经一闪而过了。

#241 表示当前线程ID,从 main线程开始,JVM 根据线程创建的顺序为线程编号。

prio 是priority优先级的缩写,表名了当前线程的优先级,取值范围为[1-10],默认为 5。在虚拟机进行线程调度的时候会参考该优先级为线程分配计算资源,这个数值越低越有优先获取到计算资源,一般不设置直接使用默认的优先级。
os_prio为线程对应系统的优先级。
nid 本地线程编号NativeID的缩写,对应JVM 虚拟机中线程映射在操作系统(本地)中的线程编号。我们可以使用 top 查看进程对应的线程情况进行相关映射。

3. jstacktop -Hp <pid>

使用 jstacktop -Hp <pid>查看进程详细信息获取目标线程的CPU使用情况

通过 jstack 可以打印出当前进程的线程栈信息,但是我们无法获取到这些线栈的 CPU 占用情况,此时,我们可以使用另外一个bash命令 top 去排查高 CPU 占用的线程。

可以看到82的进程使用CPU较大

在这里插入图片描述

然后使用 top -Hp <pid>查看该进程下对应线程的CPU 使用情况:

top -Hp 82

在这里插入图片描述

我们看到410线程占用CPU较大,这时我们通过jstack查看详情。

首先将410转换为16进制。

在这里插入图片描述

然后使用jstack 82| grep -10 19a

在这里插入图片描述

发现是prometheus的中间件占用CPU较大。

4. ps -Lf <pid>

使用 ps -Lf <pid>查看进程详细信息

在这里插入图片描述

PID:进程号
LWP:线程号

微信公众号先已开通,搜索 “江小南和他的小伙伴们” 就能找到我哦,各位小伙伴们可以关注一下,文章会进行同步更新,方便查看哦。

### 回答1: Linux jstack是一个命令行工具,用于生成Java线程转储。它可以帮助开发人员分析Java应用程序中的线程问题,如死锁、死循环等。jstack命令可以显示Java虚拟机中所有线程的状态,包括线程ID、线程名称、线程状态、线程堆栈等信息。开发人员可以使用这些信息来诊断线程问题并进行调试。 ### 回答2: linux jstack是一个用于诊断和调试Java应用程序的实用程序。它提供了一种查看Java应用程序运行时线程状态的方式,可以帮助开发人员分析线程堆栈,定位和解决应用程序中的性能问题和死锁等并发问题。 使用jstack命令可以获取Java应用程序的线程信息和线程堆栈信息。当应用程序出现性能问题时,可以使用jstack命令来查看应用程序的线程状态,以确定是否存在线程阻塞、死锁或竞争条件等问题。 使用jstack命令非常简单,只需要在终端中输入"jstack"加上Java应用程序的进程ID即可。命令执行后,会输出每个线程的ID、状态、所属的进程ID、线程堆栈信息等。通过分析线程堆栈信息,可以找到应用程序中可能存在的性能瓶颈和并发问题。 jstack命令还可以与其他性能诊断工具和分析工具配合使用。例如,可以将jstack输出的线程堆栈信息与VisualVM等工具进行对比分析,以进一步深入了解应用程序的性能瓶颈和并发问题。 总之,linux jstack是一个非常有用的工具,可以帮助开发人员诊断和调试Java应用程序。通过使用jstack命令,开发人员可以获得关于线程状态和线程堆栈信息的详细分析,以解决应用程序的性能问题和并发问题。 ### 回答3: linux jstack是一个在Linux系统上运行的命令行工具,用于生成Java线程的堆栈跟踪信息。 在Linux系统上,Java应用程序通常由Java虚拟机(JVM)执行。当JVM执行时,它会创建多个线程来并发执行不同的任务。这些线程之间可能会相互依赖,或者可能会出现死锁或其他线程相关的问题。 当出现线程相关的问题时,我们可以使用linux jstack命令来获取Java线程的堆栈跟踪信息。通过查看线程的堆栈跟踪信息,我们可以获得线程在执行过程中的详细信息,例如线程的调用栈、锁的所有权信息等。 要使用linux jstack命令,我们首先需要找到正在执行的Java应用程序的进程ID。然后,在终端中执行以下命令: jstack <PID> 其中<PID>是Java应用程序的进程ID。执行该命令后,linux jstack将生成一个包含所有Java线程的堆栈跟踪信息的输出文件。 通过分析这个输出文件,我们可以获得关于Java线程状态、锁信息、线程调用栈等详细信息。例如,我们可以查看哪个线程持有了锁、哪些线程正在等待锁等。 总而言之,linux jstack是一个用于生成Java线程堆栈跟踪信息的命令行工具。它是一个非常有用的工具,可以帮助我们在诊断和解决Java应用程序中的线程相关问题时提供有价值的信息。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

傻啦猫@_@

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值