jstack性能分析

本文介绍jstack工具在Java进程中的应用,包括如何查找高资源占用线程及其状态分析。通过实例展示如何使用jstack获取线程堆栈信息,并解释线程的不同状态及它们对系统性能的影响。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

jstack工具在jdk中,用于dump线程堆栈信息
使用方法:
1.先ps或者jps或者top找到java进程对应的PID

2.找到资源占用率高的线程id并将其转换为16进制
方法1:
ps H -eo lstart,cmd,tid,pid,%cpu| grep 15084
方法2:
top -H -p 15084
方法3:
pidstat -t -p 15084 1 1

3.将资源占用最大的线程号转换为16进制(3aed即为转换的16进制线程)
[root@master local]# printf “%x\n” 15085
3aed

4.使用jstack打印出进程的堆栈信息,输出到文件,找到对应的nid进行排查
jstack $PID > thread.log

线程的几种状态:
线程状态示意图
NEW: 线程刚创建
RUNNABLE: 线程正在运行或者就绪
WAITING: 线程正在等待某个信号
TIMED_WAITING: 也是等待某个信号,但是有超时时间
BLOCKED:表示有线程阻塞,或者求锁而不得
TERMINATED: 表示线程运行结束

	一般而言,new和terminated一般不用关注,runnable状态的线程占用cpu,waiting、timed_waiting、blocked状态的线程不耗cpu。
	进程卡的时候,也是会分不同情况的,有的是因为算法问题,代码效率低下等,这时去看线程的状态就是runnalbe的;
	有的是因为锁竞争、资源池不足造成的,这种情况下线程状态往往是waiting、timed_waiting、blocked,而且这种情况是不占用cpu的,所以又是后会发现系统占用cup很低但是程序很卡,问题就是出现在这里。

可以搞个死循环验证一下:在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值