本文将与您分享一些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暂停时间和内存分配率,而不是手动确定世代大小。
分配率和促销率
- 重要的是要跟踪应用程序的分配和提升率,以获得最佳的GC性能。
- 作为JVM人机工程学的一部分,保持GCAdaptiveSizePolicy处于活动状态。 仅在需要时手动调音。
实时数据计算
- 完整GC后,您的实时应用程序数据对应于OldGen占用率。
- 至关重要的是,您的OldGen容量必须足够大,以舒适地保存您的实时数据,并限制主要收集的频率以及对应用程序负载吞吐量的影响。
建议:首先,调整Java Heap的大小,以使OldGen占用空间或Full GC后达到约50%的占用率,从而为某些较高的负载情况(故障转移,峰值,繁忙的业务时段...)留有足够的缓冲。
- *热门* :注意OldGen内存泄漏!
- 什么是Java中的内存泄漏? 随着时间的推移,实时数据不断增加 ……
实时数据深入研究
- JVM GC日志很棒……但是如何检查实时数据呢?
- Java堆直方图快照和堆转储分析是功能强大且行之有效的方法,可以更好地了解您的应用程序实时数据。
- Java事件探查器解决方案和工具(例如Oracle Java Mission Control和Java Visual VM)提供了用于深度Java堆检查和性能分析的高级功能,包括跟踪应用程序内存分配。
世界各地的收藏:GC开销
- YoungGen收集的价格较低,但要注意分配率过高。
- 建议最初将YoungGen的大小调整为(JVM默认)堆大小的1/3。
- 请记住:YoungGen和OldGen集合都是世界停止的事件!
- PermGen和Metaspace(JDK 1.8+)是在Full GC期间收集的,因此,跟踪Class元数据足迹和GC频率非常重要。
最后的话语和建议
最佳实践
- 最佳的Java性能不仅仅与Java有关……探索所有角度。
- 始终依靠事实而非猜测。
- 首先关注全局调整项,而过早的细粒度优化则要重点。
- 如果适用,请执行性能和负载测试。
- 充分利用经过验证的工具和故障排除技术。
避免
- 有许多可能的JVM参数:不要过度调整JVM!
- 您始终会担心自己不了解的内容:良好的应用程序知识>无惧>更好的调优建议。
- 永远不要以为您的应用程序性能是最佳的。
- 不要试图立即解决所有问题,而要逐步进行调整。
- 不要感到困惑,要专注于性能问题的根本原因而不是症状。
- 过度尝试和错误的方法:猜测的症状。
翻译自: https://www.javacodegeeks.com/2015/07/jvm-buzzwords-java-developers-should-understand.html