GC overhead limit exceeded

港控/mmm° 2024-02-19 19:53 169阅读 0赞

overhead limit exceeded:垃圾回收不过来。GC占用cpu过高,一直在运行。

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

模拟案例:

  1. public class GCOverhead {
  2. public static void main(String[] args) {
  3. int a=0;
  4. List<String> list=new ArrayList<>();
  5. try {
  6. while (true){
  7. list.add(String.valueOf(++a).intern());
  8. }
  9. } catch (Throwable e) {
  10. throw e;
  11. }
  12. }
  13. }

watermark_type_ZmFuZ3poZW5naGVpdGk_shadow_10_text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3dlaXhpbl80MzU0OTU3OA_size_16_color_FFFFFF_t_70

解决办法:

1.查看项目中是否有大量的死循环或有使用大内存的代码,优化代码。

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

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

发表评论

表情:
评论列表 (有 0 条评论,169人围观)

还没有评论,来说两句吧...

相关阅读