Jstack排查线上CPU100%
2023-03-31 10:45:48 时间
Jstack排查线上CPU100%
介绍
jstack是JVM自带的Java堆栈跟踪工具,用于生成java虚拟机当前时刻的线程快照,来帮助定位线程出现长时间停顿的原因,例如死锁、死循环等。
语法
jstack [options] pid
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),打印JAVA和包含本地方法的C/C++的堆栈信息。
- -l:long listing. Prints additional information about locks,打印堆栈信息,包含锁的其他信息,例如死锁等。
实操
-
找出cpu使用率最高的进程
top -c
-
找出CPU使用率最高的进程,查询该pid进程下的线程使用情况
ps -mp 进程id -o THREAD,tid,time
-
将线程id转换成16进制
printf "%x " tid
-
jstack查看相应线程的堆栈
jstack 进程id | grep 16进制线程id -A 30 # 或者打印到文件 jstack pid | grep tid >> jstack.txt
扩展
JVM线程的几种状态
New
新建的线程,线程还没启动。
Runnable
线程正在运行或者等待操作系统中的其他资源,例如线程运行过程中,系统分配资源给其他操作,此时这个线程还是Runnable状态,可以理解为可运行的线程。
Blocked
阻塞状态,阻塞状态的线程正在等待监视器锁,在Dump日志中一般显示为java.lang.Thread.State: BLOCKED
Waiting
等待线程,线程正在无限期的等待另一个线程执行某些特别操作。一般线程由于调用一下方法会处于等待状态。
Object.wait // 不带超时
Thread.join // 不带超时
LockSupport.park
Time_Waiting
和Waiting类似,但是线程等待有时间限制,设定了指定等待时间。一般线程由于调用一下方法会处于超时等待状态。
Thread.sleep
Object.wait // 指定超时时间
Thread.join // 指定超时时间
LockSupport.parkNanos
LockSupport.parkUntil
Terminated
终止状态。
原文链接:https://monkey.blog.xpyvip.top/archives/jstack-pai-cha-xian-shang-cpu
相关文章
- leetcode 1301. 最大得分的路径数目
- leetcode 15. 三数之和
- LintCode 125 · 背包问题(二)---01背包问题
- leetcode 18. 四数之和
- LindCode 92 · 背包问题----01背包问题
- leetcode 416. 分割等和子集
- LintCode 440 · 背包问题 III---完全背包问题
- LintCode 464 · 整数排序 II
- leetcode 279. 完全平方数----完全背包的套路
- leetcode 322. 零钱兑换----完全背包套路解法详细再探
- 把01背包问题的底裤扒个底朝天!!!
- 今天老夫就把完全背包的底裤给你扒出来瞅瞅!!!
- 从软件历史看架构的未来:编程不再是精英们的游戏
- leetcode 518. 零钱兑换 II-----完全背包套路模板
- 今天就来揭开多重背包的面纱!!!
- leetcode 17. 电话号码的字母组合----回溯算法
- leetcode 36. 有效的数独
- leetcode 139. 单词拆分---完全背包问题之true or false类型
- leetcode 494. 目标和
- leetcode 474. 一和零