jastack查看线程状态主要关注哪些状态

jstack是用来查看JVM线程快照的命令,线程快照是当前JVM线程正在执行的方法堆栈集合。使用jstack命令可以定位线程出现长时间卡顿的原因,例如死锁,死循环等。jstack还可以查看程序崩溃时生成的core文件中的stack信息。

jstack [options]

option参数解释:

-F 当使用jstack 无响应时,强制输出线程堆栈。

-m 同时输出java堆栈和c/c++堆栈信息(混合模式)

-l 除了输出堆栈信息外,还显示关于锁的附加信息

cpu占用过高问题

  1. 使用Process Explorer工具找到cpu占用率较高的线程
  2. 在thread卡中找到cpu占用高的线程id
  3. 线程id转换成16进制
  4. 使用jstack -l 查看进程的线程快照
  5. 线程快照中找到指定线程,并分析代码

jstack检查死锁问题

public class DeadLock {
    private static Object obj1 = new Object();
    private static Object obj2 = new Object();
    public static void main(String[] args) {
        new Thread(new Thread1()).start();
        new Thread(new Thread2()).start();
    }

    private static class Thread1 implements Runnable{
        public void run() {
            synchronized (obj1){
                System.out.println("Thread1 拿到了 obj1 的锁!");
                try {
                    // 停顿2秒的意义在于,让Thread2线程拿到obj2的锁
                    Thread.sleep(2000);
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
                
                synchronized (obj2){
                   System.out.println("Thread1 拿到了 obj2 的锁!");
                }
           }
       }
   }

    private static class Thread2 implements Runnable{
        public void run() {
            synchronized (obj2){
                System.out.println("Thread2 拿到了 obj2 的锁!");
                try {
                   // 停顿2秒的意义在于,让Thread1线程拿到obj1的锁
                    Thread.sleep(2000);
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }

               synchronized (obj1){
                   System.out.println("Thread2 拿到了 obj1 的锁!");
               }
           }
        }
    }

}

执行指令:

jstack -l 11666

打印结果

Found one Java-level deadlock:

=============================

"Thread-1":

waiting to lock monitor 0x00007efc880062c8 (object 0x00000000ec1dc5c8, a java.lang.Object), which is held by "Thread-0" "Thread-0": waiting to lock monitor 0x00007efc88004e28 (object 0x00000000ec1dc5d8, a java.lang.Object), which is held by "Thread-1" Java stack information for the threads listed above: ===================================================

"Thread-1":

at DeadLock$Thread2.run(DeadLock.java:35)

- waiting to lock (a java.lang.Object)

- locked (a java.lang.Object) at java.lang.Thread.run(Thread.java:748)

"Thread-0":

at DeadLock$Thread1.run(DeadLock.java:19)

- waiting to lock (a java.lang.Object)

- locked (a java.lang.Object) at java.lang.Thread.run(Thread.java:748) Found 1 deadlock.

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值