8 年开发架构师浅析 SpringBoot 的 JVM 的内存占用与 Docker-spring

本文深入探讨了SpringBoot应用在JVM中的内存占用,特别是非堆内存的各个区域,如压缩类空间、线程、代码缓存等,并分析了它们与堆内存的区别。通过实例展示了如何使用HotSpot VM的本机内存跟踪来监测内存使用情况。文章还提及了JVM大小调整,特别是JIT代码缓存对性能的影响,强调了正确配置以有效利用RAM的重要性。
摘要由CSDN通过智能技术生成

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 面试题解析+后端开发学

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

倾听铃的声

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值