你知道哪些或者你们线上使用什么GC策略? 它有什么优势,适用于什么场景?

GC 策略

Serial收集器 一个单线程的收集器,在进行垃圾收集时候,必须暂停其他所有的工作线程直到它收集结束。 特点:CPU利用率最高,停顿时间即用户等待时间比较长。 适用场景:小型应用 通过JVM参数-XX:+UseSerialGC可以使用串行垃圾回收器。

Parallel收集器 采用多线程来通过扫描并压缩堆 特点:停顿时间短,回收效率高,对吞吐量要求高。 适用场景:大型应用,科学计算,大规模数据采集等。 通过JVM参数 XX:+USeParNewGC 打开并发标记扫描垃圾回收器。

CMS收集器 采用“标记-清除”算法实现,使用多线程的算法去扫描堆,对发现未使用的对象进行回收。 (1)初始标记 (2)并发标记 (3)并发预处理 (4)重新标记 (5)并发清除 (6)并发重置 特点:响应时间优先,减少垃圾收集停顿时间 适应场景:服务器、电信领域等。 通过JVM参数 -XX:+UseConcMarkSweepGC设置

G1收集器 在G1中,堆被划分成 许多个连续的区域(region)。采用G1算法进行回收,吸收了CMS收集器特点。 特点:支持很大的堆,高吞吐量 –支持多CPU和垃圾回收线程 –在主线程暂停的情况下,使用并行收集 –在主线程运行的情况下,使用并发收集 实时目标:可配置在N毫秒内最多只占用M毫秒的时间进行垃圾回收 通过JVM参数 –XX:+UseG1GC 使用G1垃圾回收器

GC的选择

官方推荐,需要根据应用的实际情况进行选择。在选择之前必须要对应用的堆大小、收集频率进行估算。

使用SerialGC的场景:
1、如果应用的堆大小在100MB以内。
2、如果应用在一个单核单线程的服务器上面,并且对应用暂停的时间无需求。
使用ParallelGC的场景:
如果需要应用在高峰期有较好的性能,但是对应用停顿时间无高要求(比如:停顿1s甚至更长)。
使用G1、CMS场景:
1、对应用的延迟有很高的要求。
2、如果内存大于6G请使用G1。

猜你喜欢

转载自blog.csdn.net/qq_33583322/article/details/81239607