推荐生产环境使用-server参数
特点是启动速度比较慢,但运行时性能和内存管理效率很高。
一、-XX:-UseGCOverheadLimit
关闭GCOverheadLimit特性,GCoverheadlimitexceeded原因:通过统计GC时间来预测是否要OOM了,当超过98%的时间用来做GC并且回收了不到2%的堆内存,就会抛出这个错误(提前预知,没啥用,该OOM还是会OOM,关闭)
二、-XX:+HeapDumpOnOutOfMemoryError
当JVM发生OOM时,自动生成DUMP文件。也可以通过-XX:HeapDumpPath=/tmp/heapdump.hprof 参数指定保存DUMP文件的路径,如果不指定,默认为当前启动JVM的目录,默认文件名:java_
三、-XX:OnOutOfMemoryError="sh ~/restart.sh"
当出现OOM时,指定某个脚本来完成一些动作,比如邮件知会、自动重启等
四、 -verbose:gc
用于垃圾收集时的信息打印,等同于-XX:+PrintGC
解读:例如第一个回收打印,箭头前后的数据939557K和406935K分别表示垃圾收集GC前后所有存活对象使用的内存容量,说明有939557K-406935K=532622K的对象容量被回收,括号内的数据2010624K为堆内存的总容量,收集所需要的时间是0.0623900秒(这个时间在每次执行的时候会有所不同)
五、-XX:+PrintGCDetails
常见格式有以下几种:
1、293.289: [Full GC [PSYoungGen: 6577K->0K(310720K)] [Times: user=0.33 sys=0.00, real=0.33 secs]
2、[PSOldGen: 102295K->102198K(134208K)] 108873K->102198K(444928K) [Times: user=0.33 sys=0.00, real=0.33 secs]
3、[PSPermGen: 59082K->58479K(104192K)], 0.3332354 secs] [Times: user=0.33 sys=0.00, real=0.33 secs]
4、[GC [PSYoungGen: 301488K->13798K(323072K)] 917963K->639822K(1022464K), 0.0323700 secs] [Times: user=0.11 sys=0.01, real=0.04 secs]
对应说明:
1、Full GC表示执行全局垃圾回收。[PSYoungGen: 6577K->0K(310720K)] 提供新生代空间信息。
2、[PSOldGen: 102295K->102198K(134208K)]提供了年老代空间信息;108873K->102198K(444928K)整个堆空间信息;
3、[PSPermGen: 59082K->58479K(104192K)]提供了持久代空间信息。
六、-XX:+PrintGCTimeStamps
详解(举例第一个):
分为4个区域看,(jvm运行时间、新生代内存,总堆内存,gc时间)
1、jvm运行时间:16.802是从jvm启动直到垃圾收集发生所经历的时间,GC表示这是一次Minor GC(新生代垃圾收集);
2、新生代大小:[PSYoungGen: 148800K->288K(265216K)] 提供了新生代空间的信息,148800K表示垃圾收集之前新生代占用空间,288K表示垃圾收集之后新生代的空间。新生代又细分为一个Eden区和两个Survivor区,Minor GC之后Eden区为空,288K就是Survivor占用的空间。括号里的265216K表示整个年轻代的大小。
3、java堆大小:618451K->470043K(964608K),表示垃圾收集之前(618451K)与之后(470043K)Java堆的大小(总堆964608K,堆大小包括新生代和年老代)
由新生代和Java堆占用大小可以算出年老代占用空间,如,Java堆大小964608K,新生代大小265216K那么年老代占用空间是964608K-265216K=699392k;
4、gc时间:0.0039130 secs表示垃圾收集过程所消耗的时间。
[Times: user=0.01 sys=0.00, real=0.01 secs] 提供cpu使用及时间消耗,user是用户模式垃圾收集消耗的cpu时间,实例中垃圾收集器消耗了0.01秒用户态cpu时间,sys是消耗系统态cpu时间,real是指垃圾收集器消耗的实际时间。