【JVM性能调优】- 合理分配堆空间

1、合理的堆空间该如何分配

Java内存各分区的大小对JVM的性能影响很大,不恰当的空间大小可能会埋下很多故障隐患,同时也会直接或间接影响JVM的提升速率、分配速率,所以如何将各分区调整到合适的大小就成了一个棘手的问题。大部分不具备线上JVM调优实操经验的开发者都会茫然,通常会认为设定的越大越好,但答案却并非如此。

在指定各区域大小时,可以依据"活跃数据"大小来进行设定,"活跃数据"是指应用程序稳定运行后长期存活在堆中的对象,也就是FullGC后年老代中的对象。一般在计算"活跃数据大小",都会多次采集程序稳定执行后的FullGC日志,通过取平均值的方式计算出堆中长期存活的年老代总量大小。

计算出"活跃数据大小"后,就可以根据其具体值计算出其他分区恰当的值,比例如下:

  • ①堆空间:活跃数据大小的4~5
  • ②新生代:活跃数据大小的1.5~2
  • ③年老代:活跃数据大小的2.5~3
  • ④元空间:活跃数据大小的1.2~1.8

假设此时观测出的"活跃数据大小"为800MB,那堆空间的各区域的大小:

  • ①堆空间:3200MB
  • ②新生代:1200MB
  • ③年老代:2000MB

当然,这仅作为初始值参考,具体情况取决于应用业务的特性和需求。

但需注意的是:实际过程中,-Xmx、-Xms两个参数设定的值必须一致,这样做的好处在于可以避免动态伸缩时带来的性能损耗与空间震荡,因为当JVM内存不足向OS申请内存时都会触发一次全局GC。

相关推荐
多多*2 小时前
Threadlocal深度解析 为什么key是弱引用 value是强引用
java·开发语言·网络·jvm·网络协议·tcp/ip·mybatis
2501_941801765 小时前
Java高性能数据库操作实战:异步任务与多线程结合代码解析
jvm
用户84913717547165 小时前
Tomcat 为什么要“造反”?深度解析 Java 类加载机制的“守”与“破”
java·jvm
杀死那个蝈坦5 小时前
UV 统计(独立访客统计)
java·jvm·spring·kafka·tomcat·maven
野生技术架构师7 小时前
Java 经典面试题汇总:多线程 +spring+JVM 调优 + 分布式 +redis+ 算法
java·jvm·spring
酷ku的森7 小时前
JVM内存结构
jvm
他们都不看好你,偏偏你最不争气7 小时前
【iOS】数据持久化
jvm·数据库·macos·ios·oracle·objective-c·cocoa
MediaTea7 小时前
Python 库手册:gc 垃圾回收
java·开发语言·jvm·python·算法
j***12157 小时前
java进阶1——JVM
java·开发语言·jvm
SoleMotive.15 小时前
如果用户反映页面跳转得非常慢,该如何排查
jvm·数据库·redis·算法·缓存