一、取得GC信息
-verbose:gc -XX:+printGC -XX:+PrintGCDetails -XX:+PrintGCTimeStamps -Xloggc:c:\gc.log
二、堆分配参数总结
- -Xms:设置Java应用程序启动的初始堆大小,一般设置成和-Xmx一样可以减少minor GC次数
- -Xmx:设置java应用程序能获得的最大堆大小,设置太小会增加GC次数,太大会增加GC时间
- -Xss:设置线程栈的大小,与支持的线程数相关 这个就要依据你的程序,看一个线程 大约需要占用多少内存,可能会有多少线程同时运行等。一般不易设置超过1M
- -XX:MinHeapFreeRatio:设置堆空间的最小空闲比例。当堆空间的空闲内存小于这个数值时,JVM变回扩展空间
- -XX:MaxHeapFreeRatio:置堆空间的最大空闲比例。当堆空间的空闲内存大于这个数值时,JVM变回扩展空间
- -Xmn:Sun官方推荐配置为整个堆的3/8
- -XX:NewSize:设置新生代的大小
- -XX:NewRatio:设置老年代和新生代的比例 等于老年代大小/新生代大小
- -XX:SurviorRatio:设置新生代中eden区与survivior区的比例
- -XX:PermSize:设置永久区的初始值 默认是物理内存的1/64
- -XX:MaxPermSize:设置最大的永久区大小 默认是物理内存的1/4
- -XX:TargetSurvivorRatio :设置survivior区的可使用率,当survivior区的空间使用率达到这个数值时,会将对象送入老年代
- -XX:+DisableExplicitGC:禁用显式GC
- 一般Xms、Xmx设置相同,PermSize、MaxPermSize设置相同,这样可以避免伸缩堆大小带来的性能损耗
三 、与串行回收器相关的参数
- -XX:+UseSerialGC 在新生代和老年代使用串行收集器
- -XX:PretenureSizeThreshold 设置大对象直接进入老年代的阀值,当对象超过这个值时,将直接在老年代分配,这个参数只对串行收集器有效
- -XX:MaxTenuringThreshold 设置对象进入老年代的年龄的最大值,每一次minorGC后 对象的年龄就+1,任何大于这个年龄的对象,一定会进入老年代,默认是15
四、与并行GC相关的参数
- -XX:+UseParNewGC :在新生代使用并行收集器
- -XX:+UseParallelOldGC:老年代使用并行回收收集器
- -XX:ParallelGCThreads:设置用于垃圾回收的线程数,通常情况下可以和CPU数量相等。但在CPU数量比较多的情况下,设置相对较小
- -XX:MaxGCPauserMillis 设置最大垃圾收集停顿时间。他的值是一个大于0的整数,在收集器工作时,会调整JAVA堆大小或则其他一些参数,尽可能地把停顿时间控制在MaxGCPauseMillls内
- -XX:GCTimeRatio:设置吞吐量的大小,它的值是一个0到100的整数,系统花费不超过1/(1+n)的时间用于垃圾收集,默认99
- -XX:+UseAdaptiveSizePolicy 自适应GC策略
五 、与CMS回收器相关的参数
1、启用CMS:-XX:+UseConcMarkSweepGC。
2。CMS默认启动的回收线程数目是 (ParallelGCThreads + 3)/4) ,如果你需要明确设定,可以通过-XX:ParallelCMSThreads=20来设定,其中ParallelGCThreads是年轻代的并行收集线程数
3、CMS是不会整理堆碎片的,因此为了防止堆碎片引起full gc,通过会开启CMS阶段进行合并碎片选项:-XX:+UseCMSCompactAtFullCollection,开启这个选项一定程度上会影响性能,
4.为了减少第二次暂停的时间,开启并行remark: -XX:+CMSParallelRemarkEnabled。如果remark还是过长的话,可以开启-XX:+CMSScavengeBeforeRemark选项,强制remark之前开始一次minor gc,减少remark的暂停时间,但是在remark之后也将立即开始又一次minor gc。
5.为了避免Perm区满引起的full gc,建议开启CMS回收Perm区选项:
+CMSPermGenSweepingEnabled -XX:+CMSClassUnloadingEnabled
6.默认CMS是在tenured generation沾满68%的时候开始进行CMS收集,如果你的年老代增长不是那么快,并且希望降低CMS次数的话,可以适当调高此值:
-XX:CMSInitiatingOccupancyFraction=80
这里修改成80%沾满的时候才开始CMS回收。
7.年轻代的并行收集线程数默认是(cpu <= 8) ? cpu : 3 + ((cpu * 5) / 8),如果你希望降低这个线程数,可以通过-XX:ParallelGCThreads= N 来调整。
相关推荐
总结,理解并掌握JVM参数和GC机制是Java开发中的重要技能。通过合理配置JVM参数,我们可以有效控制内存使用,优化程序性能,并减少垃圾收集带来的负面影响。同时,根据应用特性选择合适的垃圾收集策略,能进一步提高...
### 常用JVM配置参数详解 #### 一、概述 Java虚拟机(JVM)是运行Java程序的核心环境,其性能的优劣直接影响到Java应用程序的执行效率。为了更好地控制JVM的行为并进行调优,熟悉JVM的配置参数至关重要。本文将深入...
### JVM参数配置详解 #### 一、理解JVM参数配置的重要性 Java Virtual Machine (JVM) 是运行Java程序的核心环境,其性能优化很大程度上依赖于正确的JVM参数配置。合理配置JVM参数不仅可以显著提升应用程序的运行...
5. **GC参数调整**:通过JVM参数可以调整GC行为,如-Xms、-Xmx设置堆大小,-XX:NewRatio设置新生代与老年代比例,-XX:SurvivorRatio设置新生代两个区的比例,-XX:+UseConcMarkSweepGC选择特定GC算法等。 **JVM调优*...
JVM参数调优部分未在提供的内容中显示,但一般来说,JVM参数调优会涉及到调整堆内存分配、堆外内存大小、垃圾回收器选择、新生代和老年代的比例,以及各种相关参数如-Xms、-Xmx、-Xmn、-XX:+UseG1GC等。这些调整能...
本文将总结JVM性能调优的经验和技巧,并提供一些实用的配置参数和建议。 一、堆大小设置 堆大小是JVM性能调优中的一个关键参数。堆大小的设置直接影响到系统的性能和稳定性。堆大小有三方面限制:相关操作系统的...
### 关键业务系统JVM参数推荐 #### 一、引言 在关键业务系统中,除了追求高吞吐量和低延迟之外,系统的稳定性和问题排查的便捷性同样至关重要。因此,选择合适的JVM参数变得尤为重要。本文将详细介绍一些常用的JVM...
总结,掌握JVM工具的使用、合理调整JVM参数以及精通调试技巧是优化Java应用程序的关键。开发者应根据实际应用场景,灵活运用这些工具和方法,持续监控、分析和优化,以提高系统的稳定性和性能。
"JVM&g1gc;带书签,完整版本"的学习资料提供了深入了解JVM内存管理和G1垃圾收集器的详细内容。通过对G1的理解和实践,开发者可以更好地优化Java应用的性能,降低垃圾收集对应用运行的影响,实现更高效的内存管理。这...
### JVM 6 详细参数分析 #### 概述 本文档深入探讨了Java 6 (JDK 6) 的JVM参数配置,旨在为开发者提供一份详尽的指南,帮助理解并合理设置JVM参数以优化Java应用程序的性能。本文档基于最新的SUN官方文档编写,并...
总结,JVM参数调优和垃圾回收机制是Java性能优化的关键。掌握这些知识,开发者可以更好地理解应用的内存行为,有效提升系统的稳定性和性能。在实际操作中,需要结合具体的应用场景和需求,灵活运用各种工具和策略,...
总结来说,JVM性能调优是多方面的工作,包括理解内存结构、选择合适的垃圾收集器、调整内存参数以及优化代码实现。通过细致入微的调优,可以显著提升Java应用的性能和稳定性。这份PDF资料将详细介绍这些关键点,帮助...
了解和掌握这些JVM相关知识,对于优化Java应用的性能、避免内存泄漏以及解决问题具有重要意义。在实际工作中,开发者可以根据应用程序的需求,通过调整JVM参数来达到最佳的运行效果。同时,利用各种监控工具,如...
本文将详细解析JVM的内存结构、内存分配策略以及相关的配置参数。 1. **JVM内存结构** JVM内存主要分为以下几个区域: - **方法区(Method Area)**:这是所有线程共享的区域,存储类信息、常量、静态变量、...
以下是对JVM内存结构、垃圾回收机制及其相关面试问题的详细解答: 1. JVM内存区域: - **堆内存**:存放所有的Java对象实例,是所有线程共享的区域。在Java 8之前,它包括年轻代(Young Generation)、年老代(Old...
总结,理解JVM的Full GC并进行有效调优,是提升Java应用性能的关键。开发者需要深入学习JVM内存模型,合理设置内存参数,选择合适的垃圾收集器,并利用监控工具进行实时分析,才能避免不必要的Full GC,从而优化系统...
了解堆内存的结构、GC回收机制以及相关参数,能够帮助开发者更好地优化JVM内存配置,解决内存溢出(OutOfMemoryError)等问题。根据实际应用需求和服务器硬件条件,通过调整这些参数,可以有效控制内存分配和垃圾...