今天继续GC系列第三篇,熬夜不易,欢迎一键三连,给个鼓励,不点赞也没关系,我还可以,谢谢捧场[捂脸]。
常见垃圾回收器组合设定
在oracle官网上可以看到如何开启使用指定垃圾回收的命令:
https://docs.oracle.com/javase/8/docs/technotes/tools/unix/java.html
垃圾回收器通常是组合使用的,我根据官网总结一下常见垃圾回收器的组合。
- -XX:+UseConcMarkSweepGC
启用CMS垃圾收集器用于老年代。
当以吞吐量为主的垃圾回收器(-XX:+UseParallelGC)无法满足应用程序的延时要求时,Oracle建议使用的垃圾回收器是CMS或者G1(-XX:+UseG1GC)
默认情况下,此选项是禁用的,HotSpot VM会根据计算机的配置和JDK版本自动选择收集器。
启用此选项后,-XX:+UseParNewGC选项将自动开启,并且不应禁用它,因为在JDK 8中不推荐使用以下选项组合:-XX:+UseConcMarkSweepGC -XX:-UseParNewGC。
而CMS一旦老年代产生了很多内存碎片,它还会使用Serial Old进行清除。
所以,-XX:+UseConcMarkSweepGC=ParNew+CMS+Serial Old
- -XX:+UseG1GC
启用G1垃圾回收器。
它适用于具有大量RAM的多处理器计算机。它能满足GC暂停时间目标,同时保持良好的吞吐量。
建议将G1收集器用于需要大堆(大小约为6 GB或更大)且GC延迟要求有限(稳定且可预测的暂停时间低于0.5秒)的应用程序。
- -XX:+UseParallelGC
使用并行清除垃圾收集器(也称为吞吐量收集器)来利用多个处理器来提高应用程序的性能。
默认情况下,此选项是禁用的,HotSpot根据计算机的配置和JDK版本自动选择收集器。
如果启用,则 -XX:+UseParallelOldGC选项也将自动启用,除非明确禁用它。
所以,-XX:+UseParallelGC=Parallel Scavenge+Parallel Old
- -XX:+UseParallelOldGC
FullGC时使用ParallelOld。默认情况下,此选项是禁用的。
-XX:+UseParallelGC时,会自动-XX:+UseParallelOldGC。
- -XX:+UseParNewGC
支持在年轻代中使用并行线程进行收集。
默认情况下,此选项是禁用的。
当设置-XX:+UseConcMarkSweepGC选项时,它将自动启用。
在JDK 8中,不建议使用-XX:+UseParNewGC选项而不使用-XX:+UseConcMarkSweepGC选项,也就是说ParNew和CMS最好同时启用,不要强行开一个禁一个。
- -XX:+UseSerialGC
启用Serial GC。
对于不需要垃圾回收具有任何特殊功能的小型和简单的应用程序,这通常是最佳选择。
默认情况下,此选项是禁用的,并且将根据计算机的配置和JVM的类型自动选择收集器。
-XX:+UseSerialGC=Serial New+Serial Old。
查看JDK默认的垃圾回收器
使用如下命令
java -XX:+PrintCommandLineFlags -version
可以查看当前使用的JDK版本、虚拟机名称及使用的垃圾回收器。
JDK 1.8 HotSpot VM默认GC是ParallelGC
JDK 11 HotSpot VM默认GC是G1
JVM常用命令参数
JVM命令可从如下网站查阅:
https://docs.oracle.com/javase/8/docs/technotes/tools/unix/java.html
HotSpot参数分类
- 标准 -开头,所有的HotSpot都支持,比如
java -version
保证Java虚拟机(JVM)的所有实现都支持标准选项。它们用于常见操作,例如检查JRE版本,设置类路径,启用详细输出等。
- 非标准 -X开头,特定版本HotSpot支持特定命令
非标准选项是特定于Java HotSpot虚拟机的通用选项,因此不能保证所有JVM实现都支持它们,并且它们可