Windows如何使用jstack跟踪异常代码

主要使用了jps和jstack命令及procexp.exe工具

Jps常用命令整理

Jps(Java Virtual MachineProcess Status Tool)是JDK 1.5提供的一个显示当前所有Java进程pid命令

1、 jps :列出pid和Java主类名

2、 jps -l:列出pid和Java主类全称

3、 jps -lm:列出PID、主类全称和应用程序参数

4、 jps –v:列出pid和JVM参数

JStack常用命令整理

Jstack是Java虚拟机自带的一种堆栈跟踪工具。Jstack用于打印出给定的Java进程ID或core file或远程调试服务的Java堆栈信息,如果是在64位机器上,需要指定选项”-J-d64”,Windows的jstack使用方式只支持以下的这种方式

Jstack [–l] pid 

主要分为两个功能: 

a  针对活着的进程做本地的或远程的线程dump 

b  针对core文件做线程dump

jstack用于生成java虚拟机当前时刻的线程快照。线程快照是当前java虚拟机内每一条线程正在执行的方法堆栈的集合,生成线程快照的主要目的是定位线程出现长时间停顿的原因,如线程间死锁、死循环、请求外部资源导致的长时间等待等。线程出现停顿的时候通过jstack来查看各个线程的调用堆栈,就可以知道没有响应的线程到底在后台做什么事情,或者等待什么资源。如果java程序崩溃生成core文件,jstack工具可以用来获得core文件的java stacknative stack的信息,从而可以轻松地知道java程序是如何崩溃和在程序何处发生问题。另外,jstack工具还可以附属到正在运行的java程序中,看到当时运行的java程序的javastack和native stack的信息, 如果现在运行的java程序呈现hung的状态,jstack是非常有用的。

线程状态

想要通过jstack命令来分析线程的情况的话,首先要知道线程都有哪些状态,下面这些状态是我们使用jstack命令查看线程堆栈信息时可能会看到的线程的几种状态:

NEW,未启动的。不会出现在Dump中。

RUNNABLE,在虚拟机内执行的。运行中状态,可能里面还能看到locked字样,表明它获得了某把锁。

BLOCKED,受阻塞并等待监视器锁。被某个锁(synchronizers)block住了。

WATING,无限期等待另一个线程执行特定操作。等待某个conditionmonitor发生,一般停留在park(), wait(), sleep(),join() 等语句里。

TIMED_WATING,有时限的等待另一个线程的特定操作。和WAITING的区别是wait() 等语句加上了时间限制 wait(timeout)

TERMINATED,已退出的。

Procexp.exe工具

ProcessExplorer(procexp)是一款进程监视工具,网上百度吧。

其他的不说了:

案例:执行,死循环

第一步:怎样找到进程ID(PID),PID为13616


第二步:怎样用jstack输出线程快照日志,存放到d盘的log.txt

第三步:怎样用procexp.exe工具快速定位线程ID,并跟踪,切换十进制转换成十六进制


第四步:打开log.txt文件,搜索1A60,跟举例的代码对应上

ok,完事了。



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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值