1. 获取资源timeout:

    异常信息如下:

    Caused by: java.sql.SQLException: An attempt by a client to checkout a Connection has timed out.
    [Cause: com.mchange.v2.resourcepool.TimeoutException:
    A client timed out while waiting to acquire a resource from com.mchange.v2.resourcepool.BasicResourcePool@4d5a39b7 -- timeout at awaitAvailable()

    查找发现,获取connection资源timeout的地方,在basicResourcePool类的awaitAvailable方法里,代码很简单:

     private void awaitAvailable(long timeout) throws InterruptedException, TimeoutException, ResourcePoolException
    {
    assert Thread.holdsLock( this ); if (force_kill_acquires)
    throw new ResourcePoolException("A ResourcePool cannot acquire a new resource -- the factory or source appears to be down."); Thread t = Thread.currentThread();
    try
    {
    acquireWaiters.add( t ); int avail;
    long start = ( timeout > 0 ? System.currentTimeMillis() : -1);
    if (Debug.DEBUG && Debug.TRACE == Debug.TRACE_MAX)
    {
    if ( logger.isLoggable( MLevel.FINE ) )
    logger.fine("awaitAvailable(): " +
    (exampleResource != null ?
    exampleResource :
    "[unknown]") );
    trace();
    }
    while ((avail = unused.size()) == 0)
    {
    // the if case below can only occur when 1) a user attempts a
    // checkout which would provoke an acquire; 2) this
    // increments the pending acquires, so we go to the
    // wait below without provoking postAcquireMore(); 3)
    // the resources are acquired; 4) external management
    // of the pool (via for instance unpoolResource()
    // depletes the newly acquired resources before we
    // regain this' monitor; 5) we fall into wait() with
    // no acquires being scheduled, and perhaps a managed.size()
    // of zero, leading to deadlock. This could only occur in
    // fairly pathological situations where the pool is being
    // externally forced to a very low (even zero) size, but
    // since I've seen it, I've fixed it.
    if (pending_acquires == 0 && managed.size() < max)
    _recheckResizePool(); this.wait(timeout);
    if (timeout > 0 && System.currentTimeMillis() - start > timeout)
    throw new TimeoutException("A client timed out while waiting to acquire a resource from " + this + " -- timeout at awaitAvailable()");
    if (force_kill_acquires)
    throw new CannotAcquireResourceException("A ResourcePool could not acquire a resource from its primary factory or source.");
    ensureNotBroken();
    }
    }
    finally
    {
    acquireWaiters.remove( t );
    if (acquireWaiters.size() == 0)
    this.notifyAll();
    }
    }

    抛出异常的是第44行,而抛出异常的先决条件就是timeout了。表象来看是这样,再继续跟进代码的时候发现,进入等待资源的先决条件是:

    1、available==0(unused==0)
    2、managed。size>=max(池数量已达到最大)
    3、获取到的资源异常:如果设置了checkedoutTest这一项时,进行test的时候失败,导致异常;

    所以更直接的原因是以下几种:

    1、请求资源的队列太长,排队时间太长导致超时:线程数量应付不过来大量的请求数量,导致超时
    2、testConnection的原因导致的异常:网络震荡
    3、数据库服务器端无更多的链接可用

    那么相应的解决方案:

    1、请求资源过长的,加大maxsize,如果请求量过大的,尽量将min和max设置成一个值,因此不存在shrink和expand的操作,这也是一种性能消耗
    2、testConnection设置在checkin即可,checkout时无需test,否则卡在网络震荡就不好了
    3、检查数据库端的最大链接数。
    4、将c3p0的debug日志打开,检查它的managed、unused、available的分别size
  2. deadlock  

c3p0--常见异常的更多相关文章

  1. orcal 数据库 maven架构 ssh框架 的全xml环境模版 及常见异常解决

    创建maven项目后,毫不犹豫,超简单傻瓜式搞定dependencies(pom.xml 就是maven的依赖管理),这样你就有了所有你要的包 <project xmlns="http ...

  2. salesforce 零基础学习(五十四)常见异常友好消息提示

    异常或者error code汇总:https://developer.salesforce.com/docs/atlas.en-us.api.meta/api/sforce_api_calls_con ...

  3. 【转】Hibernate 常见异常

    转载地址:http://smartan.iteye.com/blog/1542137 Hibernate 常见异常net.sf.hibernate.MappingException        当出 ...

  4. Spring10种常见异常解决方法

    在程序员生涯当中,提到最多的应该就是SSH三大框架了.作为第一大框架的Spring框架,我们经常使用. 然而在使用过程中,遇到过很多的常见异常,我在这里总结一下,大家共勉. 一.找不到配置文件的异常 ...

  5. Hibernate 常见异常

    Hibernate 常见异常net.sf.hibernate.MappingException        当出现net.sf.hibernate.MappingException: Error r ...

  6. 开通博客第一天 (先发一些android(java)常见异常信息

    常见异常: java.lang.AbstractMethodError抽象方法错误.当应用试图调用抽象方法时抛出. java.lang.AssertionError断言错.用来指示一个断言失败的情况. ...

  7. iOS常见异常Exec_Bad_Access问题解决办法

    iOS常见异常Exec_Bad_Access问题解决办法     在iOS开发中,经常遇到Exec_Bad_Access异常,导致程序奔溃问题,一般这个问题都是因为过早的release对象,然后又对该 ...

  8. 大数据平台常见异常-zookeeper

    本文主要阐述大数据平台环境zookeeper常见异常和解决方案 1.Connection reset by peer异常 异常说明 我们现在项目有个任务OneMinuteDataSync是用spark ...

  9. struts2.1.8+hibernate2.5.6+spring3.0(ssh2三大框架)常见异常原因和解决方案

    ---------------------------------------------------------------------------------------------------- ...

  10. spring集成Junit做单元测试及常见异常解决办法

    spring-test依赖包 <!--Spring-test --> <!-- https://mvnrepository.com/artifact/org.springframew ...

随机推荐

  1. Jython:java调用python文件之第三方包路径问题

    本文转载自:http://blog.csdn.net/ztf312/article/details/51338060 本方法解决python代码的可移植性,不需要在新机器上配置python环境,只通过 ...

  2. python3_爬虫_爬百度音乐

    工具及环境 1.操作系统:windows 64位系统 2.软件工具:谷歌浏览器.pycharm集成开发工具 3.第三方库:request 注:如果第三方库搭建有困难,请看博客:https://www. ...

  3. VS2017如何配置openGL环境

    转自:http://blog.csdn.net/qq_26982531/article/details/62056913 这里着重介绍vs2017配置openGL环境与以前版本的不同之处:       ...

  4. python打造漏洞补丁缺少检测

    前言: 当我们进行后渗透的时候,进行提权的时候 要识别被未打补丁的漏洞.来进行提权,从而 拿到管理员权限. 思路: 1.让使用者在cmd中打systeminfo命令.将补丁号 放入一个txt. 2.与 ...

  5. Protocol入门

    参考:http://haoxiang.org/2011/08/ios-delegate-and-protocol/ 介绍: Protocol在iOS中就是协议,简单的理解就是一组函数的集合,这个集合中 ...

  6. apache配置https和http的时候You don't have permission to access / on this server.

    You don't have permission to access / on this server. 是由于没有设置访问目录 今天配置httpd-ssl.conf的时候  发现这个问题 由于默认 ...

  7. tomcat安装出现问题及解决方法

    1. tomcat安装: 安装目录-->D:\Program Files\apache-tomcat-7.0.59 2. tomcat环境变量配置: 3. D:\Program Files\ap ...

  8. MyBatis 注解式开发

  9. nodejs-supervisor

    小技巧——使用 supervisor 如果你有 PHP 开发经验,会习惯在修改 PHP 脚本后直接刷新浏览器以观察结果,而你在开发 Node.js 实现的 HTTP 应用时会发现,无论你修改了代码的哪 ...

  10. LevelDB Compaction操作

    [LevelDB Compaction操作] 对于LevelDb来说,写入记录操作很简单,删除记录仅仅写入一个删除标记就算完事,但是读取记录比较复杂,需要在内存以及各个层级文件中依照新鲜程度依次查找, ...