Jstack排查线上CPU100%()

  本篇文章为你整理了Jstack排查线上CPU100%()的详细内容,包含有jstack cpu 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使用率最高的进程,查询该pid进程下的线程使用情况

  

ps -mp 进程id -o THREAD,tid,time

 

  

 

  
线程正在运行或者等待操作系统中的其他资源,例如线程运行过程中,系统分配资源给其他操作,此时这个线程还是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

  以上就是Jstack排查线上CPU100%()的详细内容,想要了解更多 Jstack排查线上CPU100%的内容,请持续关注盛行IT软件开发工作室。

郑重声明:本文由网友发布,不代表盛行IT的观点,版权归原作者所有,仅为传播更多信息之目的,如有侵权请联系,我们将第一时间修改或删除,多谢。

留言与评论(共有 条评论)
   
验证码: