GC overhead limit exceeded 问题解决

今天练习时出现了一个很奇怪的异常:java.lang.OutOfMemoryError: GC overhead limit exceeded ,超出了GC开销限制。科普了一下,这个是JDK6新添的错误类型。是发生在GC占用大量时间为释放很小空间的时候发生的,是一种保护机制。一般是因为堆太小,导致异常的原因:没有足够的内存。 

Sun 官方对此的定义:超过98%的时间用来做GC并且回收了不到2%的堆内存时会抛出此异常。

为什么会出现这个问题呢?原因是我在实践一个电影推荐系统项目时用ALS算法训练模型,其所需的训练数据比较庞大,又设置了较大的迭代次数,导致内存占用过大。
 

解决办法:

1,查看项目中是否有大量的死循环或有使用大内存的代码,优化代码。比如在我的项目里,我在需要重复计算的地方加上cache()做一个缓存,提高运算效率

2,JVM给出这样一个参数:-XX:-UseGCOverheadLimit  禁用这个检查,其实这个参数解决不了内存问题,只是把错误的信息延后,替换成 java.lang.OutOfMemoryError: Java heap space。

3,增大堆内存 set JAVA_OPTS=-server -Xms512m -Xmx1024m -XX:MaxNewSize=1024m -XX:MaxPermSize=1024m
 

你可能感兴趣的:(BUG填坑)