jstack命令测试

jstack用于打印出给定的java进程ID或core file或远程调试服务的Java堆栈信息。

命令格式

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)	可能是产生core dump的java可执行程序,连接core文件
    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

  • pid 为需要打印配置信息的Java进程号
  • -F当’jstack [-l] pid’没有相应的时候强制打印栈信息
  • -l长列表. 打印关于锁的附加信息,例如属于java.util.concurrent的ownable synchronizers列表.
  • -m打印java和native c/c++框架的所有栈信息.
  • -h | -help打印帮助信息

使用示例 检查死锁

  1. 运行一个产生死锁的程序
import java.util.concurrent.TimeUnit;
import java.util.concurrent.locks.ReentrantLock;

/**
 * @author zxg
 */
public class TestDeadLock {

    private static ReentrantLock lock1 = new ReentrantLock();
    private static ReentrantLock lock2 = new ReentrantLock();

    public static void main(String[] args) {
        Thread t1 = new Thread(() -> {
            lock1.lock();
            System.out.println(Thread.currentThread().getName() + " get lock1");
            try {
                TimeUnit.SECONDS.sleep(1);
                System.out.println(Thread.currentThread().getName() + " try to get lock2");
                lock2.lock();
            } catch (InterruptedException e) {
                e.printStackTrace();
            } finally {
                lock1.unlock();
            }
        }, "thread1");
        Thread t2 = new Thread(() -> {
            lock2.lock();
            System.out.println(Thread.currentThread().getName() + " get lock2");
            try {
                TimeUnit.SECONDS.sleep(1);
                System.out.println(Thread.currentThread().getName() + " try to get lock1");
                lock1.lock();
            } catch (InterruptedException e) {
                e.printStackTrace();
            } finally {
                lock2.unlock();
            }
        }, "thread2");

        t1.start();
        t2.start();
    }
}

程序造成死锁没有停止。
在这里插入图片描述

  1. 查看该java进程号
    Ctrl+Shift+Esc
    在这里插入图片描述

  2. 统计线程数
    jstack -l 7776 | grep 'java.lang.Thread.State' | wc -l
    在这里插入图片描述

  3. jstack查看输出
    在这里插入图片描述

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

zxg45

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

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

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

打赏作者

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

抵扣说明:

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

余额充值