为什么 jmap 和 jcmd 生成的堆转储大小存在差异?

Vip*_*pin 8 java jmap heap-dump java-8 jcmd

我正在尝试使用以下 2 个命令进行堆转储

  1. jcmd $pid GC.heap_dump /tmp/filename.dump
  2. jmap -dump:format=b,file=/tmp/filename.dump $pid

jcmd 产生 ~300M 的文件大小,jmap 产生 ~1.4G 的文件大小。为什么这些是不同的大小,我们在 jmap 中有任何其他信息吗?我在 jcmd 中遗漏了一些参数吗?

JDK 是 1.8.0_162

Xms 和 Xmx 是 4G

Nar*_* SP 10

默认情况下(当没有提供 [options] 时],

JMAP 进行所有对象转储,而 JCMD 仅进行活动对象转储。

使用 JMAP 命令:在使用此命令时,您不需要指定任何内容,因为默认情况下它会生成所有对象的堆转储。如果您只需要活动对象,您可以在 JMAP 中传递 '-dump:live' 选项。

使用 JCMD 命令:使用此命令时,您必须传递 -all 选项。否则,它将请求完整的 GC 并仅生成活动对象转储。

JCMD - 没有任何对象状态选项 - 默认情况下它只转储活动对象。

JMAP - 没有任何对象状态选项 - 默认情况下它会转储所有对象。

有关更多信息,请参阅此处