JVM 的非堆内存分为几个不同的区域。我们可以使用 HotSpot VM 的本机内存跟踪(NMT)来检查这些区域的内存使用情况。请注意,虽然 NMT 不跟踪所有原生本机 Native 内存使用情况(例如,它不跟踪第三方本机代码内存分配),但对于大类典型的 Spring 应用程序来说已经足够了。可以通过启动应用程序-XX:NativeMemoryTracking=summary 然后使用 jcmd VM.native_memory summary 来显示内存使用情况摘要来使用 NMT 。
让我们通过查看应用程序来说明 NMT 的使用,在这种情况下,我们的老朋友 Petclinic。下面的饼图显示了当使用 48MB 最大堆(-Xmx48M)启动 Petclinic 时由 NMT 报告的 JVM 的内存使用量(减去其自身的开销):
正如您所看到的,非堆内存占绝大多数 JVM 的内存使用量,堆内存仅占总数的六分之一。在这种情况下,大约 44MB(垃圾收集后立即使用 33MB)。非堆内存使用总量为 223MB。
[](()本机 Native 内存区域
-
压缩类空间:用于存储有关已加载的类的信息。受到约束 MaxMetaspaceSize。已加载的类数的函数。
-
线程:JVM 中线程使用的内存。正在运行的线程数的函数。
-
代码缓存:JIT 用于存储其输出的内存。已加载的类数的函数 《一线大厂 Java 面试题解析+后端开发学