我怀疑我的应用程序有内存泄漏。我有 GC 日志,当我查看它们时,我看到内存使用量约为 9-10GB。然后我尝试将内存转储到文件中,文件大小约为5GB。
问题是为什么转储没有 9GB 的大小,而只有 5GB?如何强制 jrcmd 转储全部内存?
我使用的命令:
jrcmd 11906 hprofdump filename=/path_to_dump/dump.hprof
JVM:
Java(TM) Platform, Standard Edition for Business (build 1.5.0_28-b04)
Oracle JRockit(R) (build R28.1.3-11-141760-1.5.0_28-20110301-1432-linux-x86_64, compiled mode)
更新:
问题是,由于GC日志,内存永远不会释放到低于9GB的水平。JDK 工具将转储截断为 5GB。为什么?
我假设JRockit的行为类似于HotSpot:如果你的实时数据集只有5 GB,那么转储也只有5 GB。我假设您的 9-10 中只有 5 GB 是实时的。
您的 GC 日志是什么样的?
顺便说一句,您是否尝试过名为Memleak的JRockit任务控制工具?它可用于查找内存泄漏。