GC参数

原创 2018年04月15日 12:47:44

串行收集器

最古老,最稳定,效率高,可能会产生较长的停顿。


-XX:+UseSerialGC
新生代、老年代使用串行回收
新生代复制算法
老年代标记-压缩

并行收集器

ParNew


-XX:+UseParNewGC
新生代并行
老年代串行
Serial收集器新生代的并行版本
复制算法
多线程,需要多核支持

-XX:ParallelGCThreads 限制线程数量

Parallel收集器


类似ParNew
新生代复制算法
老年代 标记-压缩
更加关注吞吐量
-XX:+UseParallelGC 
使用Parallel收集器+ 老年代串行
-XX:+UseParallelOldGC

使用Parallel收集器+ 并行老年代

-XX:MaxGCPauseMills
最大停顿时间,单位毫秒
GC尽力保证回收时间不超过设定值
-XX:GCTimeRatio
0-100的取值范围
垃圾收集时间占总时间的比
默认99,即最大允许1%时间做GC
这两个参数是矛盾的。因为停顿时间和吞吐量不可能同时调优

CMS收集器


Concurrent Mark Sweep 并发标记清除
标记-清除算法
与标记-压缩相比
并发阶段会降低吞吐量
老年代收集器(新生代使用ParNew)

-XX:+UseConcMarkSweepGC

CMS运行过程比较复杂,着重实现了标记的过程,可分为
初始标记
根可以直接关联到的对象
速度快
并发标记(和用户线程一起)
主要标记过程,标记全部对象
重新标记
由于并发标记时,用户线程依然运行,因此在正式清理前,再做修正
并发清除(和用户线程一起)

基于标记结果,直接清理对象

特点
尽可能降低停顿
会影响系统整体吞吐量和性能
比如,在用户线程运行过程中,分一半CPU去做GC,系统性能在GC阶段,反应速度就下降一半
清理不彻底
因为在清理阶段,用户线程还在运行,会产生新的垃圾,无法清理
因为和用户线程一起运行,不能在空间快满时再清理
-XX:CMSInitiatingOccupancyFraction设置触发GC的阈值

如果不幸内存预留空间不够,就会引起concurrent mode failure

-XX:+ UseCMSCompactAtFullCollection Full GC后,进行一次整理
整理过程是独占的,会引起停顿时间变长
-XX:+CMSFullGCsBeforeCompaction 
设置进行几次Full GC后,进行一次碎片整理
-XX:ParallelCMSThreads

设定CMS的线程数量

参数整理

-XX:+UseSerialGC:在新生代和老年代使用串行收集器
-XX:SurvivorRatio:设置eden区大小和survivior区大小的比例
-XX:NewRatio:新生代和老年代的比
-XX:+UseParNewGC:在新生代使用并行收集器
-XX:+UseParallelGC :新生代使用并行回收收集器
-XX:+UseParallelOldGC:老年代使用并行回收收集器
-XX:ParallelGCThreads:设置用于垃圾回收的线程数
-XX:+UseConcMarkSweepGC:新生代使用并行收集器,老年代使用CMS+串行收集器
-XX:ParallelCMSThreads:设定CMS的线程数量

-XX:CMSInitiatingOccupancyFraction:设置CMS收集器在老年代空间被使用多少后触发

-XX:+UseCMSCompactAtFullCollection:设置CMS收集器在完成垃圾收集后是否要进行一次内存碎片的整理

-XX:CMSFullGCsBeforeCompaction:设定进行多少次CMS垃圾回收后,进行一次内存压缩
-XX:+CMSClassUnloadingEnabled:允许对类元数据进行回收
-XX:CMSInitiatingPermOccupancyFraction:当永久区占用率达到这一百分比时,启动CMS回收
-XX:UseCMSInitiatingOccupancyOnly:表示只在到达阀值的时候,才进行CMS回收
Tomcat实例演示

Java内存模型 —— 深入JVM

JVM是整个Java程序运行的母体,但是大部分的开发者并不清楚JVM的执行流程。同时虽然都知道Java提供有垃圾收集机制,但是该如何进行合理的GC处理?以及该使用的GC策略也不清楚,为此本课程专门针对于JVM的执行流程、内存分配、垃圾收集等机制进行了综合讲解。官方QQ群:612148723。
  • 2016年12月31日 20:43

JVM GC参数说明

1 GC类型 1 )YGC  一般情况下,当新对象生成,并且在Eden申请空间失败时,就好触发YGC ,堆Eden区域进行GC,清除非存活对象,并且把尚且存活的对象移动到Survivor区...
  • xiongzhichao
  • xiongzhichao
  • 2017-03-10 18:48:53
  • 450

JVM gc参数设置与分析

原文: http://hi.baidu.com/i1see1you/item/295c1dc81f91ab55bdef69e5gc日志分析工具: http://qa.blog.163.com/b...
  • yohoph
  • yohoph
  • 2014-12-20 11:47:45
  • 26252

jvm gc 日志和dump参数

首页 资讯 精华 论坛 问答 博客 专栏 群组 更多 ▼ 您还未登录 ! 登录 注册 Java实践 博客 微博 相册 收藏 留言 关于我 ...
  • jiafu1115
  • jiafu1115
  • 2016-07-01 15:04:05
  • 1606

1.3垃圾回收——内存分配策略、垃圾收集器(G1)、GC算法、GC参数、对象存活的判定

垃圾收集器与内存分配策略1 概述2 对象已死吗    2.1 引用计数算法    2.2 可达性算法    2.3 再谈引用    2.4 生存or死亡    2.5 回收方法区3 垃圾收集算法   ...
  • qq_31997407
  • qq_31997407
  • 2018-03-28 22:34:05
  • 90

Java GC堆和jvm参数设置

1、堆内存 Java 中的堆是 JVM 所管理的最大的一块内存空间,主要用于存放各种类的实例对象。  在 Java 中,堆被划分成两个不同的区域:新生代 ( Young )、老年代 ( Old...
  • ls5718
  • ls5718
  • 2016-06-28 16:54:32
  • 5301

Java虚拟机--常用的GC参数(十)

串行回收器相关的参数: -XX:+UseSerialGC:在新生代和老年代使用串行收集器; -XX:SurvivorRatio:设置eden区大小和survivior区大小的比例; -XX...
  • qq_33301113
  • qq_33301113
  • 2017-04-10 17:09:33
  • 407

JVM -verbose参数详解(转)

转自:http://www.javaranger.com/archives/367 java -verbose[:class|gc|jni] 在输出设备上显示虚拟机运行信息。 1.java -ve...
  • u011897392
  • u011897392
  • 2016-11-03 14:37:20
  • 4078

HBase最佳实践-CMS GC调优

HBase最佳实践-CMS GC调优  2016年8月9日  范欣欣 HBase发展到当下,对其进行的各种优化从未停止,而GC优化更是其中的重中之重。从0.94版本提出MemStoreLAB策...
  • javastart
  • javastart
  • 2016-09-21 19:52:58
  • 1506

JVM系列之Trace跟踪GC(一)

1.输出GC的简要信息首先,我们需要创造一个GC回收的条件,正常而言,还真难创造出来。所以,我们必须借助jvm启动参数。无容置疑,堆空间大小的参数无非就是Xms和Xmx。 Xms:JVM堆空间初...
  • u010866364
  • u010866364
  • 2016-10-26 00:13:53
  • 443
收藏助手
不良信息举报
您举报文章:GC参数
举报原因:
原因补充:

(最多只允许输入30个字)