C3P0出现DEADLOCK报错
错误log:
发生 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>
- 作者是菜鸟,就是想把看过的文章(遇到的问题),记录一下,方便自己记忆。还希望各路大牛多多指点。