【1】存在大于1s的FullGC

目前有存在大于1s的FullGC,金桥的机器目前是2C4G的,使用的GC方法只能使用单线程进行串行的回收,致使GC比较慢。html

建议能够调整GC参数,改用CMS,可以解决这个问题web

参数修改方法:bash

在应用 webapp/WEB-INF/tars/prod 文件夹下,建立文件 extraenv.sh并发

文件内容app

#!/usr/bin/env bash
JAVA_OPTS="${JAVA_OPTS} -XX:+UseConcMarkSweepGC"

 

或者升级JAVA8后,默认使用CMS也能解决这个问题。webapp

 

ps:我查的跟上面说的不同(https://zhuanlan.zhihu.com/p/45558897)spa

jdk1.7 默认垃圾收集器Parallel Scavenge(新生代)+Parallel Old(老年代)
jdk1.8 默认垃圾收集器Parallel Scavenge(新生代)+Parallel Old(老年代)
jdk1.9 默认垃圾收集器G1线程

实际应该是,机器目前是2C4G,核心数太少,因此采用串行Serial收集器(并发时对CPU资源占用多,不适合CPU核心数较少的状况。htm

 

Minor GC 和 Full GC

  • 新生代GC(Minor GC):指发生在新生代的垃圾收集动做,由于Java对象大多都具有朝生夕灭的特性,因此Minor GC很是频繁,通常回收速度也比较快。具体原理见上一篇文章。
  • 老年代GC(Major GC / Full GC):指发生在老年代的GC,出现了Major GC,常常会伴随至少一次的Minor GC(但非绝对的,在Parallel Scavenge收集器的收集策略里就有直接进行Major GC的策略选择过程)。Major GC的速度通常会比Minor GC慢10倍以上。

并行和并发

  • 并行(Parallel):指多条垃圾收集线程并行工做,但此时用户线程仍然处于等待状态。
  • 并发(Concurrent):指用户线程与垃圾收集线程同时执行(但不必定是并行的,可能会交替执行),用户程序在继续运行。而垃圾收集程序运行在另外一个CPU上。

老年代收集器中:对象

Serial Old 在进行垃圾收集时,必须暂停其余全部的工做线程,直至Serial收集器收集结束为止(“Stop The World”)

 CMS(Concurrent Mark Sweep)收集器是一种以获取最短回收停顿时间为目标的收集器。从整体上来讲,CMS收集器的内存回收过程是与用户线程一块儿并发执行的(Parallel是并行)

 

垃圾收集器详情:https://www.cnblogs.com/twoheads/p/10207573.html

相关文章
相关标签/搜索