zoukankan      html  css  js  c++  java
  • GC overhead limit exceeded 与 APPARENT DEADLOCK!!! Creating emergency threads for unassigned pending

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

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

    为什么会出现这个问题呢?经过反复测试发现,下载数据时文件大小超过某一峰值是会报这个错误。原因是在页面点击下载时,在数据库查询了很庞大的数据量,导致内存使用增加,才会出现这个问题。

    解决办法:

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

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

    3,增大堆内存(根据自己需求设定) set JAVA_OPTS=-server -Xms512m -Xmx1024m -XX:MaxNewSize=1024m -XX:MaxPermSize=1024m  
     

    java.lang.OutOfMemoryError: GC overhead limit exceeded 

        这个问题,搞了好几天,后来发现是C3P0的问题,这里记录一下: 

        原c3p0参数如下: 

       <property name="maxPoolSize" value="10"/> 
       <property name="minPoolSize" value="3"/> 
       <property name="maxIdleTime" value="180" /> 


       修改后c3p0的参数如下: 

       <property name="maxPoolSize" value="30" /> 
       <property name="minPoolSize" value="10" /> 
       <property name="maxIdleTime" value="1800" /> 
       <property name="maxStatements" value="0" /> 
       <property name="initialPoolSize" value="10" /> 
       <property name="idleConnectionTestPeriod" value="1800" />

  • 相关阅读:
    Count and Say
    Valid Sudoku
    Find First and Last Position of Element in Sorted Array
    Search in Rotated Sorted Array
    Longest Valid Parentheses
    web前端中文教程库
    三代基因组拼接软件--Falcon篇
    使用ThreadPoolExecutor并行执行独立的单线程任务
    python中的计时器:timeit
    Python教程
  • 原文地址:https://www.cnblogs.com/liclBlog/p/15349527.html
Copyright © 2011-2022 走看看