jvm运行信息查看

1.jstat

查看jvm内存情况。 常用方式:jstat -[option] <pid>

Jstat是JDK自带的一个轻量级小工具。全称“Java Virtual Machine statistics monitoring tool”,它位于java的bin目录下,主要利用JVM内建的指令对Java应用程序的资源和性能进行实时的命令行的监控,包括了对Heap size和垃圾回收状况的监控。
jstat 用法
在这里插入图片描述
option: 参数选项

-t: 可以在打印的列加上Timestamp列,用于显示系统运行的时间

-h: 可以在周期性数据数据的时候,可以在指定输出多少行以后输出一次表头

vmid: Virtual Machine ID( 进程的 pid)

interval: 执行每次的间隔时间,单位为毫秒

count: 用于指定输出多少次记录,缺省则会一直打印

在这里插入图片描述
option 可以从下面参数中选择

-class 显示ClassLoad的相关信息;
-compiler 显示JIT编译的相关信息;
-gc 显示和gc相关的堆信息;
-gccapacity    显示各个代的容量以及使用情况;
-gcmetacapacity 显示metaspace的大小
-gcnew 显示新生代信息;
-gcnewcapacity 显示新生代大小和使用情况;
-gcold 显示老年代和永久代的信息;
-gcoldcapacity 显示老年代的大小;
-gcutil   显示垃圾收集信息;
-gccause 显示垃圾回收的相关信息(通-gcutil),同时显示最后一次或当前正在发生的垃圾回收的诱因;
-printcompilation 输出JIT编译的方法信息;

示例一:-class

显示加载class的数量,及所占空间等信息。

jstat -class <pid>

在这里插入图片描述
Loaded : 已经装载的类的数量
Bytes : 装载类所占用的字节数
Unloaded:已经卸载类的数量
Bytes:卸载类的字节数
Time:装载和卸载类所花费的时间

示例二: -compiler

显示VM实时编译(JIT)的数量等信息。

jstat -compiler <pid>

在这里插入图片描述
Compiled:编译任务执行数量
Failed:编译任务执行失败数量
Invalid :编译任务执行失效数量
Time :编译任务消耗时间
FailedType:最后一个编译失败任务的类型
FailedMethod:最后一个编译失败任务所在的类及方法

示例三: -gc

显示gc相关的堆信息,查看gc的次数,及时间。

jstat –gc <pid>

在这里插入图片描述

S0C:年轻代中第一个survivor(幸存区)的容量 (字节)
S1C:年轻代中第二个survivor(幸存区)的容量 (字节)
S0U :年轻代中第一个survivor(幸存区)目前已使用空间 (字节)
S1U :年轻代中第二个survivor(幸存区)目前已使用空间 (字节)
EC :年轻代中Eden(伊甸园)的容量 (字节)
EU :年轻代中Eden(伊甸园)目前已使用空间 (字节)
OC :Old代的容量 (字节)
OU :Old代目前已使用空间 (字节)
MC:metaspace(元空间)的容量 (字节)
MU:metaspace(元空间)目前已使用空间 (字节)
YGC :从应用程序启动到采样时年轻代中gc次数
YGCT :从应用程序启动到采样时年轻代中gc所用时间(s)
FGC :从应用程序启动到采样时old代(全gc)gc次数
FGCT :从应用程序启动到采样时old代(全gc)gc所用时间(s)
GCT:从应用程序启动到采样时gc用的总时间(s)

示例四: -gccapacity

可以显示,VM内存中三代(young,old,perm)对象的使用和占用大小

jstat -gccapacity <pid>

在这里插入图片描述

NGCMN :年轻代(young)中初始化(最小)的大小(字节)
NGCMX :年轻代(young)的最大容量 (字节)
NGC :年轻代(young)中当前的容量 (字节)
S0C :年轻代中第一个survivor(幸存区)的容量 (字节)
S1C : 年轻代中第二个survivor(幸存区)的容量 (字节)
EC :年轻代中Eden(伊甸园)的容量 (字节)
OGCMN :old代中初始化(最小)的大小 (字节)
OGCMX :old代的最大容量(字节)
OGC:old代当前新生成的容量 (字节)
OC :Old代的容量 (字节)
MCMN:metaspace(元空间)中初始化(最小)的大小 (字节)
MCMX :metaspace(元空间)的最大容量 (字节)
MC :metaspace(元空间)当前新生成的容量 (字节)
CCSMN:最小压缩类空间大小
CCSMX:最大压缩类空间大小
CCSC:当前压缩类空间大小
YGC :从应用程序启动到采样时年轻代中gc次数
FGC:从应用程序启动到采样时old代(全gc)gc次数

示例五:-gcmetacapacity

metaspace 中对象的信息及其占用量。

jstat -gcmetacapacity<pid>

在这里插入图片描述

MCMN:最小元数据容量
MCMX:最大元数据容量
MC:当前元数据空间大小
CCSMN:最小压缩类空间大小
CCSMX:最大压缩类空间大小
CCSC:当前压缩类空间大小
YGC :从应用程序启动到采样时年轻代中gc次数
FGC :从应用程序启动到采样时old代(全gc)gc次数
FGCT :从应用程序启动到采样时old代(全gc)gc所用时间(s)
GCT:从应用程序启动到采样时gc用的总时间(s)

示例六: -gcnew

年轻代对象的信息。

jstat -gcnew <pid>

在这里插入图片描述

S0C :年轻代中第一个survivor(幸存区)的容量 (字节)
S1C :年轻代中第二个survivor(幸存区)的容量 (字节)
S0U :年轻代中第一个survivor(幸存区)目前已使用空间 (字节)
S1U :年轻代中第二个survivor(幸存区)目前已使用空间 (字节)
TT:持有次数限制
MTT:最大持有次数限制
DSS:期望的幸存区大小
EC:年轻代中Eden(伊甸园)的容量 (字节)
EU :年轻代中Eden(伊甸园)目前已使用空间 (字节)
YGC :从应用程序启动到采样时年轻代中gc次数
YGCT:从应用程序启动到采样时年轻代中gc所用时间(s)

示例七: -gcnewcapacity

年轻代对象的信息及其占用量

jstat -gcnewcapacity <pid>

在这里插入图片描述

NGCMN :年轻代(young)中初始化(最小)的大小(字节)
NGCMX :年轻代(young)的最大容量 (字节)
NGC :年轻代(young)中当前的容量 (字节)
S0CMX :年轻代中第一个survivor(幸存区)的最大容量 (字节)
S0C :年轻代中第一个survivor(幸存区)的容量 (字节)
S1CMX :年轻代中第二个survivor(幸存区)的最大容量 (字节)
S1C:年轻代中第二个survivor(幸存区)的容量 (字节)
ECMX:年轻代中Eden(伊甸园)的最大容量 (字节)
EC:年轻代中Eden(伊甸园)的容量 (字节)
YGC:从应用程序启动到采样时年轻代中gc次数
FGC:从应用程序启动到采样时old代(全gc)gc次数

示例八: -gcold

old代对象的信息

jstat -gcold <pid>

在这里插入图片描述
MC :metaspace(元空间)的容量 (字节)
MU:metaspace(元空间)目前已使用空间 (字节)
CCSC:压缩类空间大小
CCSU:压缩类空间使用大小
OC:Old代的容量 (字节)
OU:Old代目前已使用空间 (字节)
YGC:从应用程序启动到采样时年轻代中gc次数
FGC:从应用程序启动到采样时old代(全gc)gc次数
FGCT:从应用程序启动到采样时old代(全gc)gc所用时间(s)
GCT:从应用程序启动到采样时gc用的总时间(s)

示例九:-gcoldcapacity

old代对象的信息及其占用量

jstat -gcoldcapacity <pid>

在这里插入图片描述
OGCMN :old代中初始化(最小)的大小 (字节)
OGCMX :old代的最大容量(字节)
OGC :old代当前新生成的容量 (字节)
OC :Old代的容量 (字节)
YGC :从应用程序启动到采样时年轻代中gc次数
FGC :从应用程序启动到采样时old代(全gc)gc次数
FGCT :从应用程序启动到采样时old代(全gc)gc所用时间(s)
GCT:从应用程序启动到采样时gc用的总时间(s)

示例十: - gcutil

统计gc信息

jstat -gcutil <pid>

在这里插入图片描述

S0 :年轻代中第一个survivor(幸存区)已使用的占当前容量百分比
S1 :年轻代中第二个survivor(幸存区)已使用的占当前容量百分比
E :年轻代中Eden(伊甸园)已使用的占当前容量百分比
O :old代已使用的占当前容量百分比
P :perm代已使用的占当前容量百分比
YGC :从应用程序启动到采样时年轻代中gc次数
YGCT :从应用程序启动到采样时年轻代中gc所用时间(s)
FGC :从应用程序启动到采样时old代(全gc)gc次数
FGCT :从应用程序启动到采样时old代(全gc)gc所用时间(s)
GCT:从应用程序启动到采样时gc用的总时间(s)

示例十一:-gccause

显示垃圾回收的相关信息(通-gcutil),同时显示最后一次或当前正在发生的垃圾回收的诱因。

jstat -gccause <pid>

在这里插入图片描述
LGCC:最后一次GC原因
GCC:当前GC原因(No GC 为当前没有执行GC)

示例十二: -printcompilation

当前VM执行的信息。

jstat -printcompilation <pid>

在这里插入图片描述
Compiled :编译任务的数目
Size :方法生成的字节码的大小
Type:编译类型
Method:类名和方法名用来标识编译的方法。类名使用/做为一个命名空间分隔符。方法名是给定类中的方法。上述格式是由-XX:+PrintComplation选项进行设置的

jstack

查看线程情况,命令格式:jstack [-l][-e] <pid>
Options:
-l  long listing. Prints additional information about locks
-e  extended listing. Prints additional information about threads
-? -h --help -help to print this help message

在这里插入图片描述

jmap

主要打印一些堆
Usage:
jmap -clstats <pid>
    to connect to running process and print class loader statistics
jmap -finalizerinfo <pid>
    to connect to running process and print information on objects awaiting finalization
jmap -histo[:live] <pid>
    to connect to running process and print histogram of java object heap
    if the "live" suboption is specified, only count live objects
jmap -dump:<dump-options> <pid>
    to connect to running process and dump java heap
jmap -? -h --help
    to print this help message

dump-options:
  live         dump only live objects; if not specified,
               all objects in the heap are dumped.
  format=b     binary format
  file=<file>  dump heap to <file>

Example: jmap -dump:live,format=b,file=heap.bin <pid>

jmap -dump:live,format=b,file=heap.bin

dump文件分析:
在这里插入图片描述

在这里插入图片描述

主要是dump,比如jmap -histo:live 19947是可以在线查看。

jmap -histo pid|head -n 10 查看前10位

jmap -histo pid | sort -k 2 -g -r 查看对象数最多的对象,按降序输出

jmap -histo pid | sort -k 3 -g -r 查看内存的对象,按降序输出

jhat(1.8已经废弃)

说明:有时dump出来的堆很大,在启动时会报堆空间不足的错误,可加参数:jhat -J-Xmx512m 。这个内存大小可根据自己电脑进行设置。

第三步:查看html

http://ip:7000/

  • 1
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: 您可以使用JMX(Java Management Extensions)来查看JVM运行中各个指标的情况。JMX提供了一种标准的方式来监控和管理Java应用程序,您可以使用JConsole或VisualVM等工具来连接到JVM查看各种指标,例如内存使用情况、线程数、GC情况等。您还可以使用JMX API编写自己的监控程序来获取更详细的信息。 ### 回答2: 要查看JVM运行中各个指标的情况,可以通过以下方法进行: 1. 使用命令行工具:JVM提供了一些命令行工具来查看各个指标的情况。比如,通过使用jps命令可以查看当前运行的Java进程的ID。然后,使用jstat命令可以查看内存、垃圾收集、类加载、线程信息的统计数据。另外,还可以使用jstack命令查看Java线程的堆栈信息,以及使用jmap命令来获取堆内存快照。 2. 使用JConsole工具:JConsole是一个JVM监视和管理工具,可以用来查看JVM运行时的各种指标。它可以显示堆内存、线程、类加载、垃圾收集等信息的统计数据,并提供可视化的界面进行监控和分析。 3. 使用VisualVM工具:VisualVM是一个功能丰富的JVM监视和性能分析工具,可以用来查看各个指标的详细信息。它提供了多种视图,可以实时监控内存、垃圾收集、线程、CPU使用率等运行时数据,并进行性能分析和诊断。 4. 使用第三方监控工具:除了上述的官方工具,还有一些第三方的监控工具可供选择。比如,可以使用AppDynamics、New Relic、Dynatrace等工具来监控JVM运行中的各个指标,并提供更多的分析和报警功能。 总之,通过命令行工具、JConsole、VisualVM以及第三方监控工具,可以方便地查看JVM运行中各个指标的情况,并进行性能分析和调优。 ### 回答3: 要查看JVM运行中各个指标的情况,可以使用以下几种方法: 1. 使用命令行工具:JVM提供了一些命令行工具来查看JVM运行时的指标。其中最常用的是jstat和jinfo命令。jstat命令可以实时监控JVM的各种指标,如堆内存使用情况、GC统计等;jinfo命令可以显示和修改JVM的配置参数。 2. 使用可视化工具:除了命令行工具,还可以使用一些可视化工具来查看JVM指标。比如VisualVM是一个常用的Java性能分析工具,可以实时监控JVM的各种指标,并提供图表展示,以便更直观地观察JVM运行情况。 3. 使用监控系统:除了单独的工具,还可以使用一些监控系统来监控JVM的各项指标。比如,使用Elasticsearch和Kibana可以搭建一个ELK监控系统,可通过收集和分析JVM生成的日志文件来监控JVM运行情况,并展示为图表形式。另外,Prometheus和Grafana也是常用的监控系统组合,可以方便地监控和可视化JVM的各项指标。 无论使用哪种方法,都可以通过查看和分析JVM的各项指标来了解JVM运行情况,如CPU利用率、堆内存使用率、线程数等,以及GC的频率和耗时情况等。这些指标可以帮助开发人员和运维人员更好地优化和调整JVM的配置,以提升程序的性能和稳定性。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值