jvm生产环境gc及oom有关的参数

推荐生产环境使用-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

jvm生产环境gc及oom有关的参数_第1张图片

解读:例如第一个回收打印,箭头前后的数据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是指垃圾收集器消耗的实际时间。

 

你可能感兴趣的:(java)