jstat
是一个强大的命令行工具,用于监控 Java 应用程序的运行时状态,特别是与垃圾收集(GC)相关的统计信息和内存使用情况。下面是一个使用 jstat
监控特定 Java 进程的垃圾回收统计信息的具体例子:
假设有一个正在运行的 Java 应用程序,其进程标识符(PID)为 12345
。我们想要每两秒刷新一次数据,连续监控10次其 GC 的统计信息。
命令示例:
jstat -gcutil 12345 2000 10
命令解析:
-gcutil
: 这是jstat
的选项,指定我们要查看的是与垃圾收集相关的实用度统计。它会显示各个内存区域(如 Eden、Survivor、Old Gen、Perm Gen 或 Metaspace 等,取决于 JVM 版本和配置)的使用率、已使用的空间、总空间以及最近几次垃圾收集的相关信息。12345
: 这是目标 Java 进程的 PID,确保jstat
能够连接到正确的 JVM 实例。2000
: 表示间隔时间,单位是毫秒。这里设置为2000
意味着jstat
将每隔两秒(即2000毫秒)获取并输出一次统计信息。10
: 表示查询次数,即jstat
将连续执行上述操作共10次后自动停止。如果您希望持续监控,可以省略此参数或将其设置为一个较大的数值。
执行上述命令后,您将在命令行中看到类似以下格式的输出:
S0 S1 E O M CCS YGC YGCT FGC FGCT GCT
0.00 0.00 ¼.98 57.68 93.20 88.17 .jpg 0.213 0 0.000 0.213
...
每一行代表一个采样时刻的统计数据,各列含义大致如下:
S0
和S1
:Survivor 区的使用率。E
:Eden 区的使用率。O
:Old Generation (Tenured) 区的使用率。M
:Metaspace 或 PermGen(取决于 JVM 版本)的使用率。CCS
:压缩类空间的使用率(仅在某些 JVM 版本中出现)。YGC
: 自JVM启动以来年轻代垃圾收集的次数。YGCT
: 年轻代垃圾收集所耗用的总时间。FGC
: 自JVM启动以来 full GC 的次数。FGCT
: full GC 所耗用的总时间。GCT
: 自JVM启动以来所有垃圾收集(包括年轻代和 full GC)所耗用的总时间。
这个例子展示了如何使用 jstat
监控 Java 应用程序的 GC 统计信息。根据实际需要,您可以调整选项、间隔时间和查询次数以适应不同的监控场景。