返回顶部
首页 > 资讯 > 后端开发 > Python >Java中jstat命令的使用详解
  • 713
分享到

Java中jstat命令的使用详解

2024-04-02 19:04:59 713人浏览 安东尼

Python 官方文档:入门教程 => 点击学习

摘要

目录jstat命令简介jstat命令参数输出选项-class选项-compiler选项-GC选项-gccapacity选项-gcutil选项-gccause选项-gcnew选项-gc

jstat命令简介

jstat(Java Virtual Machine Statistics Monitoring Tool)是jdk提供的一个可以监控Java虚拟机各种运行状态信息的命令行工具。它可以显示Java虚拟机中的类加载、内存、垃圾收集、即时编译等运行状态的信息。

jstat命令参数

命令语法:

jstat generalOptions
jstat outputOptions [-t] [-h<lines>] <vmid> [<interval> [<count>]]

命令参数说明:

  • generalOptions:通用选项,如果指定一个通用选项,就不能指定任何其他选项或参数。它包括如下两个选项:
    • -help:显示帮助信息。
    • -options:显示outputOptions参数的列表。
  • outputOptions:输出选项,指定显示某一种Java虚拟机信息。
  • -t:把时间戳列显示为输出的第一列。这个时间戳是从Java虚拟机的开始运行到现在的秒数。
  • -h n:每显示n行显示一次表头,其中n为正整数。默认值为 0,即仅在第一行数据显示一次表头。
  • vmid:虚拟机唯一ID(LVMID,Local Virtual Machine Identifier),如果查看本机就是Java进程的进程ID。
  • interval:显示信息的时间间隔,单位默认毫秒。也可以指定秒为单位,比如:1s。如果指定了该参数,jstat命令将每个这段时间显示一次统计信息。
  • count:显示数据的次数,默认值是无穷大,这将导致jstat命令一直显示统计信息,直到目标JVM终止或jstat命令终止。

输出选项

如果不指定通用选项(generalOptions),则可以指定输出选项(outputOptions)。输出选项决定jstat命令显示的内容和格式,具体如下:

  • -class:显示类加载、卸载数量、总空间和装载耗时的统计信息。
  • -compiler:显示即时编译的方法、耗时等信息。
  • -gc:显示堆各个区域内存使用和垃圾回收的统计信息。
  • -gccapacity:显示堆各个区域的容量及其对应的空间的统计信息。
  • -gcutil:显示有关垃圾收集统计信息的摘要。
  • -gccause:显示关于垃圾收集统计信息的摘要(与-gcutil相同),以及最近和当前垃圾回收的原因。
  • -gcnew:显示新生代的垃圾回收统计信息。
  • -gcnewcapacity:显示新生代的大小及其对应的空间的统计信息。
  • -gcold: 显示老年代和元空间的垃圾回收统计信息。
  • -gcoldcapacity:显示老年代的大小统计信息。
  • -gcmetacapacity:显示元空间的大小的统计信息。
  • -printcompilation:显示即时编译方法的统计信息。

jstat命令的显示输出被格式化为一个表,列用空格分隔。接下来,我来了解一下每条输出选项的列名。

-class选项

  • Loaded:加载的类的数量。
  • Bytes:加载的类所占用的字节数。
  • Unloaded:卸载的类的数量。
  • Bytes:卸载的类所占用的字节数。
  • Time:执行类加载和卸载操作所花费的时间。

举个例子:

-compiler选项

  • Compiled:执行的编译任务的数量。
  • Failed:执行编译任务失败的数量。
  • Invalid:执行编译任务失效的数量。
  • Time:执行编译任务所花费的时间。
  • FailedType:上次编译失败的编译类型。
  • FailedMethod:上次编译失败的类名和方法。

举个例子:

-gc选项

  • S0C:年轻代中第一个Survivor区的容量,单位为KB。
  • S1C:年轻代中第二个Survivor区的容量,单位为KB。
  • S0U:年轻代中第一个Survivor区已使用大小,单位为KB。
  • S1U:年轻代中第二个Survivor区已使用大小,单位为KB。
  • EC:年轻代中Eden区的容量,单位为KB。
  • EU:年轻代中Eden区已使用大小,单位为KB。
  • OC:老年代的容量,单位为KB。
  • OU:老年代已使用大小,单位为KB。
  • MC:元空间的容量,单位为KB。
  • MU:元空间已使用大小,单位为KB。
  • CCSC:压缩类的容量,单位为KB。
  • CCSU:压缩类已使用大小,单位为KB。
  • YGC:Young GC的次数。
  • YGCT:Young GC所用的时间。
  • FGC:Full GC的次数。
  • FGCT:Full GC的所用的时间。
  • GCT:GC的所用的总时间。

举个例子:

-gccapacity选项

  • NGCMN:年轻代最小的容量,单位为KB。
  • NGCMX:年轻代最大的容量,单位为KB。
  • NGC:当前年轻代的容量,单位为KB。
  • S0C:年轻代中第一个Survivor区的容量,单位为KB。
  • S1C:年轻代中第二个Survivor区的容量,单位为KB。
  • EC:年轻代中Eden区的容量,单位为KB。
  • OGCMN:老年代最小的容量,单位为KB。
  • OGCMX:老年代最大的容量,单位为KB。
  • OGC:当前老年代的容量,单位为KB。
  • OC:当前老年代的容量,单位为KB。
  • MCMN:元空间最小的容量,单位为KB。
  • MCMX:元空间最大的容量,单位为KB。
  • MC:当前元空间的容量,单位为KB。
  • CCSMN:压缩类最小的容量,单位为KB。
  • CCSMX:压缩类最大的容量,单位为KB。
  • CCSC:当前压缩类的容量,单位为KB。
  • YGC:Young GC的次数。
  • FGC:Full GC的次数。

举个例子:

-gcutil选项

  • S0:年轻代中第一个Survivor区使用大小占当前容量的百分比。
  • S1:年轻代中第二个Survivor区使用大小占当前容量的百分比。
  • E:Eden区使用大小占当前容量的百分比。
  • O:老年代使用大小占当前容量的百分比。
  • M:元空间使用大小占当前容量的百分比。
  • CCS:压缩类使用大小占当前容量的百分比。
  • YGC:Young GC的次数。
  • YGCT:Young GC所用的时间。
  • FGC:Full GC的次数。
  • FGCT:Full GC的所用的时间。
  • GCT:GC的所用的总时间。

举个例子:

-gccause选项

  • S0:年轻代中第一个Survivor区使用大小占当前容量的百分比。
  • S1:年轻代中第二个Survivor区使用大小占当前容量的百分比。
  • E:Eden区使用大小占当前容量的百分比。
  • O:老年代使用大小占当前容量的百分比。
  • M:元空间使用大小占当前容量的百分比。
  • CCS:压缩类使用大小占当前容量的百分比。
  • YGC:Young GC的次数。
  • YGCT:Young GC所用的时间。
  • FGC:Full GC的次数。
  • FGCT:Full GC的所用的时间。
  • GCT:GC的所用的总时间。
  • LGCC:上次垃圾回收的原因。
  • GCC:当前垃圾回收的原因。

举个例子:

-gcnew选项

  • S0C:年轻代中第一个Survivor区的容量,单位为KB。
  • S1C:年轻代中第二个Survivor区的容量,单位为KB。
  • S0U:年轻代中第一个Survivor区已使用大小,单位为KB。
  • S1U:年轻代中第二个Survivor区已使用大小,单位为KB。
  • TT:对象在年轻代存活的次数。
  • MTT:对象在年轻代存活的最大次数
  • DSS:期望的Survivor区大小,单位为KB。
  • EC:年轻代中Eden区的容量,单位为KB。
  • EU:年轻代中Eden区已使用大小,单位为KB。
  • YGC:Young GC的次数。
  • YGCT:Young GC所用的时间。

举个例子:

-gcnewcapacity选项

  • NGCMN:年轻代最小的容量,单位为KB。
  • NGCMX:年轻代最大的容量,单位为KB。
  • NGC:当前年轻代的容量,单位为KB。
  • S0CMX:年轻代中第一个Survivor区最大的容量,单位为KB。
  • S0C:年轻代中第一个Survivor区的容量,单位为KB。
  • S1CMX:年轻代中第二个Survivor区最大的容量,单位为KB。
  • S1C:年轻代中第二个Survivor区的容量,单位为KB。
  • ECMX:年轻代中Eden区最大的容量,单位为KB。
  • EC:年轻代中Eden区的容量,单位为KB。
  • YGC:Young GC的次数。
  • FGC:Full GC的次数。

举个例子:

-gcold选项

  • MC:元空间的容量,单位为KB。
  • MU:元空间已使用大小,单位为KB。
  • CCSC:压缩类的容量,单位为KB。
  • CCSU:压缩类已使用大小,单位为KB。
  • OC:老年代的容量,单位为KB。
  • OU:老年代已使用大小,单位为KB。
  • YGC:Young GC的次数。
  • FGC:Full GC的次数。
  • FGCT:Full GC的所用的时间。
  • GCT:GC的所用的总时间。

举个例子:

-gcoldcapacity选项

  • OGCMN:老年代最小的容量,单位为KB。
  • OGCMX:老年代最大的容量,单位为KB。
  • OGC:当前老年代的容量,单位为KB。
  • OC:当前老年代的容量,单位为KB。
  • YGC:Young GC的次数。
  • FGC:Full GC的次数。
  • FGCT:Full GC的所用的时间。
  • GCT:GC的所用的总时间。

举个例子:

-gcmetacapacity选项

  • MCMN:元空间最小的容量,单位为KB。
  • MCMX:元空间最大的容量,单位为KB。
  • MC:当前元空间的容量,单位为KB。
  • CCSMN:压缩类最小的容量,单位为KB。
  • CCSMX:压缩类最大的容量,单位为KB。
  • YGC:Young GC的次数。
  • FGC:Full GC的次数。
  • FGCT:Full GC的所用的时间。
  • GCT:GC的所用的总时间。

举个例子:

-printcompilation选项

Compiled:最近编译方法执行的编译任务的数量。

Size:最近编译方法的字节码的字节数。

Type:最近编译方法的编译类型。

Method:最近编译方法的类名和方法名。

举个例子:

附实例使用:统计gc信息

各列意义

S0C:年轻代中第一个存活区的大小

S1C:年轻代中第二个存活区的大小

S0U:年轻代中第一个存活区已使用的空间 (字节) 

S1U:年轻代中第二个存活区已使用的空间 (字节) 

EC:   Edem区大小

EU:   年轻代中Edem区已使用的空间 (字节) 

OC:  老年代大小

OU:  老年代已使用的空间 (字节) 

PC:   持久代大小

PU: 持久代已使用的空间 (字节) 

YGC: 从应用程序启动到采样时young gc的次数

YGCT: 从应用程序启动到采样时young gc的所用的时间(s)

FGC:  从应用程序启动到采样时full gc的次数

FGCT: 从应用程序启动到采样时full gc的所用的时间

GCT: 从应用程序启动到采样时整个gc所用的时间

如果young gc所用的时间比较长,如几秒几十秒,则肯定不正常。

# jstat -gcutil 25444

 

S0     S1     E      O      P     YGC     YGCT    FGC    FGCT     GCT
 11.63   0.00   56.46  66.92  98.49 162    0.248    6      0.331    0.579

总结

到此这篇关于Java中jstat命令使用的文章就介绍到这了,更多相关Java jstat命令使用内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: Java中jstat命令的使用详解

本文链接: https://lsjlt.com/news/143023.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • Java中jstat命令的使用详解
    目录jstat命令简介jstat命令参数输出选项-class选项-compiler选项-gc选项-gccapacity选项-gcutil选项-gccause选项-gcnew选项-gc...
    99+
    2024-04-02
  • jstat命令怎么使用
    这篇文章主要介绍了jstat命令怎么使用的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇jstat命令怎么使用文章都会有所收获,下面我们一起来看看吧。jstat的用法:jstat [ gene...
    99+
    2023-06-27
  • Java中的jinfo命令使用详解
    目录jinfo命令简介jinfo命令参数-flag name-flag [+|-]name-flag name=value-flags-sysprops-h 和 -help结尾jin...
    99+
    2024-04-02
  • java的jps命令使用详解
    jps(Java Virtual Machine Process Status Tool) 是java提供的一个显示当前所有java进程pid的命令,适合在linux/unix平台上...
    99+
    2024-04-02
  • Java中的zookeeper常用命令详解
    目录1.zkCli.sh客户端2.多节点类型创建3.查询节点4.set数据5.删除节点6.权限设置7.其他命令注意我这里用的是官方最稳定的版本3.7.1,版本之间有个别命令是有差距的...
    99+
    2024-04-02
  • Java的jstack命令使用示例详解
    目录jstack命令简介jstack命令参数-F参数-l参数-m参数-h 和 -help结尾jstack命令简介 jstack(Java Virtual Machine Stack ...
    99+
    2024-04-02
  • Linux中的screen命令使用详解
    GUN Screen: 官方网址:http://www.gnu.org/software/screen/ 1、简介 Screen是一款由GNU计划开发的用于命令行终端切换的自由软件。用户可以通过该软件同时连接多个本地...
    99+
    2022-06-04
    Linux screen命令 Linux screen
  • Git中bundle命令的使用详解
    目录1. 打包2. 验证3. 查看分支4. 导入bundle4.1. 没有gitlab服务器4.2. 有gitlab服务器4.2.1 从bundle中clone4.2.2 从bund...
    99+
    2024-04-02
  • linux中使用grep命令详解
    linux grep命令 Linux grep命令用于查找文件里符合条件的字符串;也可以用于查找内容包含指定的范本样式的文件。它能使用正则表达式搜索,用于在文件中搜索指定的字符串模式,列出含有匹配模式子符串的文件名,并输...
    99+
    2022-06-04
    linux grep
  • bash命令使用详解
    在linux上采用bash作为标准,基本上它描述了对带有“.sh”扩展名的vi编辑器等文本的处理并执行。 与编程一样,它有许多函数,如变量,函数和算术处理,所以如果你是一个小程序,你可以用bash编写它。 BNejvPy...
    99+
    2022-06-04
    bash
  • sar命令使用详解
    sar(System ActivityReporter系统活动情况报告)是目前Linux上最为全面的系统性能分析工具之一,可以从多方面对系统的活动进行报告,包括:文件的读写情况、系统调用的使用情况、磁盘I/...
    99+
    2024-04-02
  • ping命令使用详解
    概述 在网络中ping是一个使用频率非常高的网络连通性检查工具,它的作用主要有: 1、用来检测网络的连通情况和分析网络速度 2、根据域名得到服务器IP 3、根据ping返回的TTL值来判断对方所使用的操作系统及数据包经过路由器数量 我们通常...
    99+
    2023-08-19
    网络 服务器 运维
  • 详解java jinfo命令
    目录一、介绍二、jinfo命令格式三、option四、执行样例五、增加JVM打印详细GC日志参数一、介绍 jinfo(Configuration Info for Java)的作用是...
    99+
    2024-04-02
  • Linux中rz命令和sz命令使用详解大全
    sz命令 用途说明:sz命令是利用ZModem协议来从Linux服务器传送文件到本地,一次可以传送一个或多个文件。相对应的从本地上传文件到Linux服务器,可以使用rz命令。 常用参数 -a 以文本方式传...
    99+
    2022-06-04
    命令 详解 大全
  • 详解Linux time 命令的使用
    1.命令简介 time 用于统计命令执行所消耗的时间及相关系统资源等信息。time 可以显示的资源有四大项,分别是: Time resources Memory resources IO resources Com...
    99+
    2022-06-03
    Linux time Linux time命令
  • Linux seq命令的使用详解
    01. 命令概述 seq命令用于产生整数序列。 02. 命令格式 用法: seq [选项]... 尾数 seq [选项]... 首数 尾数 seq [选项]... 首数 增量 尾数 03. 常用选项 ...
    99+
    2022-06-04
    Linux seq命令 Linux seq
  • linux rm命令的使用详解
    本篇内容主要讲解“linux rm命令的使用详解”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“linux rm命令的使用详解”吧!1.命令格式:rm [选项] 文件&hellip;2.命...
    99+
    2023-06-13
  • linux route命令的使用详解
    route命令是一个用于显示和管理Linux系统中IP路由表的命令。它可以用来查看和修改系统的路由表信息。route命令的基本语法如...
    99+
    2023-09-20
    linux
  • Java的jps命令简介及使用示例详解
    目录jps命令简介jps命令参数jps命令示例结尾jps命令简介 jps(Java Virtual Machine Process Status Tool)是JDK提供的一个可以列出...
    99+
    2024-04-02
  • JDK常用命令jps jinfo jstat的具体说明与示例
    概述 JDK的bin目录下提供了很多命令工具,比如java.exe,javap.exe,javac.exe。。。。。。这些命令由jdk/lib/tools.jar类库中提供的,是对t...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作