JVM GC相关参数总结

一、取得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 来调整。

 

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值