jstat命令

本文介绍jstat工具,它是用于监控JVM运行状态信息的命令行工具。文章详细解释了jstat的各种选项及其用途,例如监视类装载、垃圾回收状况、新生代及老年代的GC情况等。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

jstat(JVM Statistics Monitoring Tool) 是用于监控JVM各种运行状态信息的命令行工具。

命令格式

jstat option vmid [ interval[s|ms] count ]

vmid:jvm进程id

interval:查询间隔支持毫秒和秒,默认毫秒

count:查询次数

option:



 
option
作用
-class 监视类装载、卸载数量、总空间以及类装载所耗费的时间
-gc 监视Java堆状况,包括Eden区、survior区、old区、永久代等的容量、已用空间、gc时间合计等信息
-gccapacity 监视内容与-gc基本相同,但输出主要关注java堆各个区域使用到的最大、最小空间
-gcutil 监视内容与-gc基本相同,但输出主要关注java堆已使用空间占总空间的百分比
-gccause 与-gcutil相同,但额外会输出导致上一次gc产生的原因
-gcnew 监视新生代gc状况
-gcnewcapacity 监视内容与-gcnew基本相同,但输出主要关注j使用到的最大、最小空间
-gcold 监视老年代gc状况
-gcoldcapacity 监视内容与-gcold基本相同,但输出主要关注j使用到的最大、最小空间
-gcpermcapacity(java7 之前) 输出永久代使用到的最大和最小空间
-gcmetacapacity(java8才有) 输出metaspace的最大和最小空间

-compiler

输出JIT编译器编译过的方法和耗时等信息
-printcompilation 输出已经被JIT编译器编译的方法

各个option以及对应输出的意义可以参考java doc

java8(java8移出了永久代,引入metaspace):http://docs.oracle.com/javase/8/docs/technotes/tools/unix/jstat.html

java7:http://docs.oracle.com/javase/7/docs/technotes/tools/share/jstat.html

### ### jstat 命令使用方法及 JVM 状态监控指南 `jstat` 是 JDK 自带的一个命令行工具,用于监控 JVM 的运行状态,尤其是垃圾回收(GC)和类加载等关键指标。它可以帮助开发者实时观察 GC 频率、耗时,检测内存泄漏趋势,并验证 JVM 参数调整的效果[^1]。 #### 基本命令格式 `jstat` 的基本命令格式如下: ```bash jstat -<option> [-t] [-h<lines>] <vmid> [<interval> [<count>]] ``` - `<option>`:指定要监控的内容,例如 `gc`、`class`、`compiler` 等。 - `<vmid>`:Java 进程的虚拟机 ID,通常为进程 PID。 - `<interval>`:采样间隔时间(单位为毫秒或秒)。 - `<count>`:采样次数。 - `-t`:输出时间戳。 - `-h<lines>`:每 `<lines>` 行输出表头。 #### 常用选项及示例 1. **监控垃圾回收情况** 使用 `-gc` 选项可以查看堆内存各区域(Eden、Survivor、Old)的使用情况以及 GC 的执行次数和耗时。 ```bash jstat -gc 23321 1000 5 ``` 上述命令将每秒输出一次 PID 为 23321 的 Java 进程的 GC 状态,共输出 5 次。输出内容包括: - `S0C/S1C`:Survivor 0/1 区的容量。 - `S0U/S1U`:Survivor 0/1 区的使用量。 - `EC/EU`:Eden 区的容量和使用量。 - `OC/OU`:Old 区的容量和使用量。 - `MC/MU`:元空间(Metaspace)的容量和使用量。 - `YGC/YGCT`:Young GC 的次数和总耗时。 - `FGC/FGCT`:Full GC 的次数和总耗时。 - `GCT`:所有 GC 的总耗时[^1]。 2. **监控类加载状态** 使用 `-class` 选项可以查看类加载的统计信息,包括加载类的数量、卸载类的数量以及类加载耗时。 ```bash jstat -class 23321 ``` 3. **监控编译器状态** 使用 `-compiler` 选项可以查看 JIT 编译器的状态,包括已执行的编译任务数、失败的编译任务数以及编译耗时。 ```bash jstat -compiler 23321 ``` 4. **带时间戳输出** 使用 `-t` 参数可以在输出中添加时间戳,便于分析时间序列数据。 ```bash jstat -gc -t 23321 1000 ``` 5. **控制表头输出频率** 使用 `-h` 参数可以指定每隔多少行输出一次表头,便于在长时间运行的监控中识别数据。 ```bash jstat -gc -h5 23321 1000 ``` #### 监控要素与性能分析 JVM 监控通常包括以下关键要素: - **内存使用情况**:包括堆内存和非堆内存的分配与使用情况。 - **线程状态**:活动线程数、守护线程数等。 - **GC 行为**:各区域的 GC 次数、耗时及频率。 - **CPU 占用率**:Java 进程的 CPU 使用情况。 通过 `jstat` 的输出,可以判断是否存在频繁的 GC(如 `YGC` 或 `FGC` 频繁发生),从而推测是否存在内存泄漏或堆内存配置不合理的问题。此外,通过对比不同时间点的 GC 耗时和内存使用情况,可以验证 JVM 参数调整的效果。 #### 结合其他工具进行综合分析 除了 `jstat`,还可以结合以下工具进行更全面的 JVM 监控与调优: - **`jstack`**:用于分析线程堆栈,定位死锁或线程阻塞问题。 - **`jmap`**:用于生成堆转储快照,分析内存泄漏。 - **`jinfo`**:用于查看和动态修改 JVM 参数。 - **`jconsole` / `jvisualvm`**:图形化工具,提供实时监控和详细分析功能。 通过这些工具的综合使用,开发者可以更深入地理解 JVM 的工作原理,并在实际工作中进行有效的监控和调优,确保 Java 应用的高效运行[^2]。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值