Java jstat和jcmd对元空间内存给出了不同的答案
我目前正在调查一个压缩的类空间问题。我知道问题是什么,但在调查时,我注意到Java jstat和jcmd对元空间内存给出了不同的答案,java,jvm,metaspace,jstat,jcmd,Java,Jvm,Metaspace,Jstat,Jcmd,我目前正在调查一个压缩的类空间问题。我知道问题是什么,但在调查时,我注意到jstat-gc…和jcmd。。。GC.heap_info提供不同数量的元空间和压缩类空间容量和使用率: ▶ jcmd 32152 GC.heap_info 32152: PSYoungGen total 153600K, used 129316K [0x00000000eab00000, 0x00000000f5b00000, 0x0000000100000000) eden space 137728K,
jstat-gc…
和jcmd。。。GC.heap_info
提供不同数量的元空间和压缩类空间容量和使用率:
▶ jcmd 32152 GC.heap_info
32152:
PSYoungGen total 153600K, used 129316K [0x00000000eab00000, 0x00000000f5b00000, 0x0000000100000000)
eden space 137728K, 91% used [0x00000000eab00000,0x00000000f26abf48,0x00000000f3180000)
from space 15872K, 16% used [0x00000000f4100000,0x00000000f439d428,0x00000000f5080000)
to space 15872K, 0% used [0x00000000f3180000,0x00000000f3180000,0x00000000f4100000)
ParOldGen total 290816K, used 21446K [0x00000000c0000000, 0x00000000d1c00000, 0x00000000eab00000)
object space 290816K, 7% used [0x00000000c0000000,0x00000000c14f1ac0,0x00000000d1c00000)
Metaspace used 59690K, capacity 64980K, committed 65192K, reserved 1103872K
class space used 9289K, capacity 10116K, committed 10152K, reserved 1048576K
▶ jstat -gc 32152
S0C S1C S0U S1U EC EU OC OU MC MU CCSC CCSU YGC YGCT FGC FGCT GCT
15872.0 15872.0 2677.0 0.0 137728.0 126711.2 290816.0 21446.7 63400.0 58060.7 9896.0 9067.2 8 0.047 3 0.118 0.164
堆容量的数字似乎总体上是匹配的(幸存者、伊甸园和老世代所有容量都一致)。堆使用率数字并不完全匹配,但我不希望它们匹配jstat
是在jcm
之后大约一秒钟收集的。但是元空间的数字都是关闭的,jstat
数字通常略低于jcmd
数字。我重新运行了这两个命令,以确认调用之间没有发生类加载,而且,实际上,这两个命令为元空间号提供了与以前相同的输出
这是怎么回事?他们对这些数字的衡量是否略有不同?哪个更准确
运行时信息:
JVM: Java HotSpot(TM) 64-Bit Server VM (25.202-b08, mixed mode)
Java: version 1.8.0_202, vendor Oracle Corporation
-Xmx1024m
-XX:+UseParallelGC
接得好!数字确实不同:jstat值可能会稍微落后,因为它们确实落后,而jcmd值总是最新的 因此,
jcmd GC.heap\u info
应该更准确
还要注意,jstat输出中的
MC
对应的是元空间提交的大小,而不是容量。Ah!这完全有道理!刚刚注意到手册页实际上说的是“垃圾收集堆统计”;手册页将MC定义为元空间容量。有什么区别?我假设这里的容量是当前分配的容量,而不是最大容量。@BryanHead关于元空间容量与已提交容量与保留容量的比较: