jdk8默认使用G1(Garbage First Garbage Collector),G1是一款面向服务端应用的牢记收集器。
G1特点:
- 并行与并发;
- 分代收集
- 空间整合
- 可预测的停顿
jvm参数说明:
-Xmx20M 设置JVM最大可用内存为20M
-Xms20M 设置JV初始内存为20M,此值可以设置与-Xmx相同,以避免每次垃圾回收完成后JVM重新分配内存。
-Xmn10M 设置年轻代内存为10M,整个JVM内存大小=年轻代大小 + 年老代大小 + 持久代大小。持久代一般固定大小为64m,所以增大年轻代后,将会减小年老代大小。此值对系统性能影响较大,Sun官方推荐配置为整个堆的3/8。
-Xss128k 设置每个线程的堆栈大小。JDK5.0以后每个线程堆栈大小为1M,以前每个线程堆栈大小为256K。更具应用的线程所需内存大小进行调整。在相同物理内存下,减小这个值能生成更多的线程。但是操作系统对一个进程内的线程数还是有限制的,不能无限生成,经验值在3000~5000左右。
-XX:MaxPermSize=16m 设置持久代大小为16m。
–XX:NewRatio=4:设置年轻代(包括Eden和两个Survivor区)与年老代的比值(除去持久代)。设置为4,则年轻代与年老代所占比值为1:4,年轻代占整个堆栈的1/5。
-XX:SurvivorRatio=8 设置新生代中Eden去与一个Survivor区的空间比例是8:1,[有两个Survivor区]。
-XX:+PrintGCDetails 内存溢出时Dump出当前的内存堆转储快照。
-XX:MaxTenuringThreshold=0 设置垃圾最大年龄。如果设置为0的话,则年轻代对象不经过Survivor区,直接进入年老代。对于年老代比较多的应用,可以提高效率。如果将此值设置为一个较大值,则年轻代对象会在Survivor区进行多次复制,这样可以增加对象再年轻代的存活时间,增加在年轻代即被回收的概论。
-XX:+HeapDumpOnOutOfMemoryError 内存溢出时Dump出当前的内存堆转储快照
-XX:+PrintGCDetails 打印GC信息