栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

【Linux篇】jstack命令简介

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

【Linux篇】jstack命令简介

jatack命令简介

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

1. 帮助文档
[root@jiangnan ~]# jstack --help
Usage:
    jstack [-l] 
        (to connect to running process)
    jstack -F [-m] [-l] 
        (to connect to a hung process)
    jstack [-m] [-l]  
        (to connect to a core file)
    jstack [-m] [-l] [server_id@]
        (to connect to a remote debug server)

Options:
    -F  to force a thread dump. Use when jstack  does not respond (process is hung)(强制打印线程栈信息,在jstack 命令没有响应的时候添加该选项可以实现强制打印)
    -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  

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

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

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

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

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

3. jstack ,top -Hp

使用 jstack ,top -Hp 查看进程详细信息获取目标线程的CPU使用情况

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

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

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

top -Hp 82

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

首先将410转换为16进制。

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

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

4. ps -Lf

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

PID:进程号
LWP:线程号

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

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/871625.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号