jstat命令

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
...

每一行代表一个采样时刻的统计数据,各列含义大致如下:

  • S0S1: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 统计信息。根据实际需要,您可以调整选项、间隔时间和查询次数以适应不同的监控场景。

相关推荐
Bug退退退1234 小时前
JVM 内存结构
jvm
那我掉的头发算什么9 小时前
【javaEE】多线程--认识线程、多线程
java·jvm·redis·性能优化·java-ee·intellij-idea
堕落年代1 天前
JVM新生代转老年代机制详解
jvm
235161 天前
【JVM】Java为啥能跨平台?JDK/JRE/JVM的关系?
java·开发语言·jvm·spring boot·后端·spring·职场和发展
AAA卷不动了1 天前
JVM(二)------ 类加载、初始化与单例模式的联系
java·jvm·单例模式
程序员卷卷狗1 天前
JVM 内存结构与 GC 调优全景图
java·开发语言·jvm
闲人编程1 天前
构建一个短链接生成器服务(FastAPI + SQLite)
jvm·python·sqlite·fastapi·生成器·短链接·caodecapsule
Boop_wu2 天前
[Java EE] 多线程 -- 初阶(1)
java·jvm·算法
小满、2 天前
对象住哪里?——深入剖析 JVM 内存结构与对象分配机制
java·jvm·#java对象分配·#hotspot实现
笑我归无处2 天前
强引用、软引用、弱引用、虚引用详解
java·开发语言·jvm