Jvm知识学习(五)-GC参数

一,JAVA堆
Java 堆是被所有线程共享的一块内存区域,在虚拟机启动时创建。这个区域是用来存放对象实例的,几乎所有对象实例都会在这里分配内存。堆是Java垃圾收集器管
的主要区域(GC堆),垃圾收集器实现了对象的自动销毁。Java堆可以细分为:新生代和老年代;再细致一点的有Eden空间,From Survivor空间,To Survivor空间
等。 Java堆可以处于物理上不连续的内存空间中,只要逻辑上是连续的即可,就像我们的磁盘空间一样。可以通过-Xmx和-Xms控制
二,串行收集器
(1)最古老,最稳定
(2)效率高
(3)可能会产生较长的停顿
(4)-XX:+UseSerialGC
    新生代、老年代使用串行回收 
     新生代复制算法 
    老年代标记-压缩 
使用示例图:

三,并行收集器
1,ParNew收集器
(1)参数:-XX:+UseParNewGC
          新生代并行 
          老年代串行 
(2)Serial收集器新生代的并行版本
(3)复制算法
(4)多线程,需要多核支持
(5)-XX:ParallelGCThreads:限制线程数量
使用示例图:

2,Parallel收集器
(1)参数:-XX:+UseParallelGC(使用Parallel收集器+ 老年代串行)        
      类似ParNew
      新生代复制算法
      老年代 标记-压缩
      更加关注吞吐量
(2)参数:-XX:+UseParallelOldGC(使用Parallel收集器+ 并行老年代
使用示例图:

并行收集器参数:
-XX:MaxGCPauseMills : 最大停顿时间,单位毫秒 , GC尽力保证回收时间不超过设定值 
-XX:GCTimeRatio : 0-100的取值范围, 垃圾收集时间占总时间的比 , 默认99,即最大允许1%时间做GC 
这两个参数是矛盾的: GC 很频繁,最大停顿时间变短,吞吐量变小, GC 很少,最大停顿时间变长,吞吐量增大。

因此停顿时间和吞吐量不可能同时调优 


三,CMS收集器
CMS收集器: Concurrent Mark Sweep 并发(与用户进程一起执行)标记清除,使用 标记-清除算法,并发阶段会降低吞吐量,老年代收集器(新生代使用ParNew)。
参数:-XX:+UseConcMarkSweepGC

CMS运行过程比较复杂,着重实现了标记的过程,可分为
(1)初始标记 :根可以直接关联到的对象,速度快。 
(2)并发标记(和用户线程一起) :主要标记过程,标记全部对象 
(3)重新标记 :由于并发标记时,用户线程依然运行,因此在正式清理前,再做修正 
(4)并发清除(和用户线程一起) :基于标记结果,直接清理对象 
使用示例图:
CMS收集器特点 :
(1)尽可能降低停顿
(2)会影响系统整体吞吐量和性能
    比如,在用户线程运行过程中,分一半CPU去做GC,系统性能在GC阶段,反应速度就下降一半
(3)清理不彻底
   因为在清理阶段,用户线程还在运行,会产生新的垃圾,无法清理
    因为和用户线程一起运行,不能在空间快满时再清理
(4)-XX:CMSInitiatingOccupancyFraction设置触发GC的阈值
如果不幸内存预留空间不够,就会引起concurrent mode failure
如下图:

碎片:当进行标记清除时,会产生一定量的内存碎片。
CMS收集器参数:
-XX:+ UseCMSCompactAtFullCollection: Full GC后,进行一次整理 ,
整理过程是独占的,会引起停顿时间变长 
-XX:+CMSFullGCsBeforeCompaction: 
设置进行几次Full GC后,进行一次碎片整理 
-XX:ParallelCMSThreads :
设定CMS的线程数量 

四,GC参数整理
-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实例演示
环境 :Tomcat 7,JSP 网站
工具 :JMeter 
目的 :测试网站吞吐量和延时,让Tomcat有一个不错的吞吐量 
系统结构:


示例1:


示例2:

示例3:

示例4:

示例5:

示例6:

示例7:

示例8:

示例9:与示例8相比,jdk的升级可以提升性能。

总结:



猜你喜欢

转载自blog.csdn.net/hhq12/article/details/80906896