首页IT科技jstack dump命令(Jstack排查线上CPU100%)

jstack dump命令(Jstack排查线上CPU100%)

时间2025-06-14 22:01:17分类IT科技浏览4937
导读:Jstack排查线上CPU100% 介绍...

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\n" 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

创心域SEO版权声明:以上内容作者已申请原创保护,未经允许不得转载,侵权必究!授权事宜、对本内容有异议或投诉,敬请联系网站管理员,我们将尽快回复您,谢谢合作!

展开全文READ MORE
python里绝对值函数(python绝对和相对导入的介绍) c++中fopen_s什么意思(【C标准库】详解fopen函数 一篇让你搞懂fopen函数)