java性能调优工具——jstack

java性能调优工具——jstack

jstack
Prints Java thread stack traces for a Java process, core file, or remote debug server.
为Java进程、核心文件或远程调试服务器打印Java线程堆栈跟踪。
jstack是java自带的工具
位置在java目录的bin目录下
找不到的话可以用whereis去查找

[root@localhost ~]# whereis jstack
jstack: /usr/local/jdk1.8.0_161/bin/jstack

jstack用法

[root@localhost ~]# jstack -help
Usage:
    jstack [-l] <pid>
        (to connect to running process)
    jstack -F [-m] [-l] <pid>
        (to connect to a hung process)
    jstack [-m] [-l] <executable> <core>
        (to connect to a core file)
    jstack [-m] [-l] [server_id@]<remote server IP or hostname>
        (to connect to a remote debug server)

Options:
    -F  to force a thread dump. Use when jstack <pid> does not respond (process is hung)
    -m  to print both java and native frames (mixed mode)
    -l  long listing. Prints additional information about locks
    -h or -help to print this help message

参数说明

  1. -F:强制打印栈信息。在jstack [-l] 没有响应的时候使用,一般情况不使用。
  2. -m:打印java和native c/c++ 框架的所有栈信息
  3. -l:打印有关锁的附加信息
  4. -h|-help 打印帮助信息

一般情况下使用 jstack pid

jstack使用

使用jps找到需要监控的java进程的pid
在这里插入图片描述
在这里插入图片描述

通过 jstack 命令可以获取当前进程的所有线程信息。
每个线程堆中信息中,都可以查看到 线程ID、线程的状态(wait、sleep、running 等状态)、是否持有锁信息等。
重点关注有没有大量的wait或者有死锁Deadlock

线程状态
NEW,未启动的。不会出现在Dump中。
RUNNABLE,在虚拟机内执行的。
BLOCKED,受阻塞并等待监视器锁。(重点关注)
WATING,无限期等待另一个线程执行特定操作。(重点关注)
TIMED_WATING,有时限的等待另一个线程的特定操作。(重点关注)
TERMINATED,已退出的。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

zhaixing_0307

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值