Java开发人员应了解的JVM流行语

本文将与您分享一些JVM“流行语”,它们对于Java开发人员在执行任何JVM性能和垃圾回收调优之前理解和记住非常重要。 本文末尾还提供了一些技巧,包括一些高级性能调优最佳实践。 将来的文章中将探讨有关Oracle HotSpot并发GC收集器(例如CMS和G1)的更多建议。

在继续阅读之前,建议您首先熟悉JVM详细的GC日志。 掌握此JVM数据分析技能至关重要,尤其是与更高级的APM技术结合使用时。

JVM流行语

分配率 分配给YoungGen空间的Java对象,

亦称“短暂”对象。

促销率 Java对象从
YoungGen来
OldGen空间。
实时数据 坐在OldGen空间中的Java对象,也称为“长寿”对象。
世界停止收集 垃圾收集,例如Full GC,并导致应用程序线程暂时挂起,直到完成。

首先,JVM GC日志

  • 提供有关Java堆和GC活动的开箱即用的详细信息。
  • 使用GCMV (GC内存可视化工具)之类的工具来评估JVM暂停时间和内存分配率,而不是手动确定世代大小。

Java开发人员应了解的JVM流行语

Java开发人员应了解的JVM流行语

分配率和促销率

  • 重要的是要跟踪应用程序的分配和提升率,以获得最佳的GC性能。
  • 作为JVM人机工程学的一部分,保持GCAdaptiveSizePolicy处于活动状态。 仅在需要时手动调音。

Java开发人员应了解的JVM流行语

Java开发人员应了解的JVM流行语

实时数据计算

  • 完整GC后,您的实时应用程序数据对应于OldGen占用率。
  • 至关重要的是,您的OldGen容量必须足够大,以舒适地保存您的实时数据,并限制主要收集的频率以及对应用程序负载吞吐量的影响。

建议:首先,调整Java Heap的大小,以使OldGen占用空间或Full GC后达到约50%的占用率,从而为某些较高的负载情况(故障转移,峰值,繁忙的业务时段等)留有足够的缓冲区。 。

  • *热门* :注意OldGen内存泄漏!
  • 什么是Java中的内存泄漏? 随着时间的推移,实时数据不断增加 ……

Java开发人员应了解的JVM流行语

实时数据深入研究

  • JVM GC日志很棒……但是如何检查实时数据呢?
  • Java堆直方图快照和堆转储分析是功能强大且行之有效的方法,可以更好地了解您的应用程序实时数据。
  • Java事件探查器解决方案和工具(例如Oracle Java Mission Control和Java Visual VM)提供了用于深度Java堆检查和性能分析的高级功能,包括跟踪应用程序内存分配。

Java开发人员应了解的JVM流行语

世界各地的收藏:GC开销

  • YoungGen收集的价格较低,但要注意分配率过高。
  • 建议最初将YoungGen的大小调整为(JVM默认)堆大小的1/3。
  • 请记住:YoungGen和OldGen集合都是世界停止的事件!
  • PermGen和Metaspace(JDK 1.8+)是在Full GC期间收集的,因此,跟踪Class元数据足迹和GC频率非常重要。

Java开发人员应了解的JVM流行语

Java开发人员应了解的JVM流行语

最后的话语和建议

最佳实践

  • 最佳的Java性能不仅仅与Java有关……探索所有角度。
  • 始终依靠事实而非猜测。
  • 首先关注全局调整项,而过早的细粒度优化则要重点。
  • 如果适用,请执行性能和负载测试。
  • 充分利用经过验证的工具和故障排除技术。

避免

  • 有许多可能的JVM参数:不要过度调整JVM!
  • 您始终会担心自己不了解的内容:良好的应用程序知识>无惧>更好的调优建议。
  • 永远不要以为您的应用程序性能是最佳的。
  • 不要试图立即解决所有问题,而要逐步进行调整。
  • 不要感到困惑,要专注于性能问题的根本原因而不是症状。
  • 过度尝试和错误的方法:猜测的症状。

翻译自: https://www.javacodegeeks.com/2015/07/jvm-buzzwords-java-developers-should-understand.html