C3P0出现DEADLOCK报错

错误log:

C3P0出现DEADLOCK报错

发生 DEADLOCK 的前提条件:

1 连接池会进行expandPool操作,因为这样才能产生AcquireTask对象,这个对象会阻塞内部连接池,因此,如果把minPoolSize和maxPoolSize设置为一样大可以避免这个问题

2 AcquireTask的执行持续很长时间,要大于10秒,在实际环境中是有可能放生的

3 acquireIncrement要大于numHelperThreads,这样才有可能把所有内部线程都占用

4 连接池的访问压力要很大,压力线程数要大于连接池现有的连接数

 

程序解决:

程序中使用的C3P0的版本0.9.5.2

添加C3P0提供的一个辅助jar

<dependency>

<groupId>com.mchange</groupId>

<artifactId>mchange-commons-java</artifactId>

<version>0.2.15</version>

</dependency>
  • 作者是菜鸟,就是想把看过的文章(遇到的问题),记录一下,方便自己记忆。还希望各路大牛多多指点。