目前有存在大于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
老年代收集器中:对象
Serial Old 在进行垃圾收集时,必须暂停其余全部的工做线程,直至Serial收集器收集结束为止(“Stop The World”)。
CMS(Concurrent Mark Sweep)收集器是一种以获取最短回收停顿时间为目标的收集器。从整体上来讲,CMS收集器的内存回收过程是与用户线程一块儿并发执行的(Parallel是并行)
垃圾收集器详情:https://www.cnblogs.com/twoheads/p/10207573.html