该问题主要原因是gc次数超过限制后,回收内存很少(不到5%?)引起的。
1. 增大任务堆内存-Xmx,或者增大并行任务数
2.-Xss减小,这种不知道是否有效? 这个对cant create native thread有效,但GC overhead limit ?
3. 减小总的执行线程数以减少线程频繁丢弃内存碎片的频率,也是一种办法。
贴一段其他人的分析,觉得不错:
通常原因都是因为old区占用过多导致频繁Full GC,最终导致GC overhead limit exceed。如果gc log不够可以借助于JProfile等工具查看内存的占用,old区是否有内存泄露。分析内存泄露还有一个方法-XX:+HeapDumpOnOutOfMemoryError,这样OOM时会自动做Heap Dump,可以拿MAT来排查了。还要留意young区,如果有过多短暂对象分配,可能也会抛这个异常。
本文分析了GCoverheadLimitExceeded异常的原因及解决方案,包括调整-Xmx参数、减小-Xss参数以及减少执行线程数。此外还提供了使用JProfile等工具进行内存分析的方法。
9410

被折叠的 条评论
为什么被折叠?



