侧边栏壁纸
博主头像
Monkey部落博主等级

Monkey部落,分享技术、经验、遇到的问题及解决方法,欢迎大家互相讨论分享。

  • 累计撰写 59 篇文章
  • 累计创建 36 个标签
  • 累计收到 2 条评论

目 录CONTENT

文章目录

Jstack排查线上CPU100%

Monkey部落
2022-10-01 / 0 评论 / 0 点赞 / 200 阅读 / 649 字

Jstack排查线上CPU100%

介绍

jstack是JVM自带的Java堆栈跟踪工具,用于生成java虚拟机当前时刻的线程快照,来帮助定位线程出现长时间停顿的原因,例如死锁、死循环等。

语法

jstack [options] pid

options:

  1. -F:to force a thread dump. Use when jstack does not respond (process is hung),当一个进程挂起时,jstack 命令没有响应时,强制输出这个线程转储信息。
  2. -m:to print both java and native frames (mixed mode),打印JAVA和包含本地方法的C/C++的堆栈信息。
  3. -l:long listing. Prints additional information about locks,打印堆栈信息,包含锁的其他信息,例如死锁等。

实操

  1. 找出cpu使用率最高的进程

    top -c
    
  2. 找出CPU使用率最高的进程,查询该pid进程下的线程使用情况

    ps -mp 进程id -o THREAD,tid,time
    
  3. 将线程id转换成16进制

    printf "%x\n" tid
    
  4. 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

终止状态。

关注微信公众号「平哥技术站」, 每日更新,在手机上阅读所有教程,随时随地都能学习。

觉得写的还不错的小伙伴,请作者喝杯咖啡☕ ,支持一下。😊

如有侵权请立即与我们联系,我们将及时处理,联系邮箱:865934097@qq.com。

0

评论区