Java Bug 定位排查工具—— JDK 内置工具

背景:程序员编写代码难免会出现BUG,这时使用简单、功能强大的BUG定位排查工具就显得非常必要了。再也不必逐行阅读源码排查问题、通宵熬夜掉头发了。: p

前提:执行一下命令需要在执行命令的机器上安装JDK,并配置该JDK的环境变量。

1. JPS — 获取JVM进程列表

直接在终端执行jps命令,获取到当前机器上JVM进程列表。
在这里插入图片描述

2. jinfo — 获取JVM进程的参数配置信息

使用 jinfo 命令并制定JVM进程的 pid ,获取该JVM进程的参数配置信息。我们可以通过该命令获取我们想要关注的 JVM 进程的参数配置情况,例如JDK版本、堆大小、文件编码格式、垃圾回收器种类等等。
在这里插入图片描述
在这里插入图片描述
ps:该命令产生的信息较多。

3. jvisualvm — 分析 JVM 健康状况的可视化工具

打开jvisualvm工具,选择要进行分析的Java进程,我在这里选择了运行的math-game Jar 包;
在这里插入图片描述
在【监控】功能下,可以观察到该Java进程的CPU使用情况,堆/Metaspace空间使用情况,类加载和Java进程中的存活线程情况。在此处还可以进行手动的垃圾回收和堆dump文件的生成。我们从下面的示例图可以看到进行了一次GC,加载了大约1600+个类,大概有10个活跃线程。
在这里插入图片描述
此外,通过jvisualvm的【线程】功能可以观察到该Java进程中的线程状态及运行状况,并可以通过抽样器和Profiler进行性能分析。

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

4. jconsole — 观察各内存区域GC情况的可视化工具

我们在使用时首先打开jconsole,选择要进行分析的Java进程。

在这里插入图片描述

选择要进行分析的内存类型,就可以观察到该类型内存的使用情况曲线图。该图的下部还列出了已使用的、未使用的内存大小、GC的次数与耗时等。

在这里插入图片描述

5. jstat — 在终端显示的参数统计数据

如果我们没有使用图形化界面工具的条件,可以通过jstat工具来查看Java进程的参数统计情况。我们在下面使用jstat 命令查看了pid 为2635289 的Java进程的GC 情况,每500毫秒输出一次,一共输出10次。

在这里插入图片描述

s0:survivor0区使用比例;
s1:survivor1区使用比例;
E:Eden区内存使用比例;
O:老年代使用比例;
M: 元数据区使用比例;
YGC:年轻代GC次数;
YGCT:年轻代GC耗时;
FGC:老年代GC次数;
FGCT:老年代GC耗时;
GCT:所有GC 的耗时;

6. jstack — 抓取线程栈

指定要观察Java进程的PID,获取该Java进程的所有线程栈信息,示例如下。

在这里插入图片描述

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值