关于C3P0超过最大连接数问题

heavenbirdliao 2012-06-12 08:50:37
这几天我在测试C3P0数据库连接池技术时,发现在超过最大连接数后再去申请数据库连接,程序会一直处于等待状态,无任何异常抛出。请问如何获取这类异常信息?
测试代码如下:

import java.beans.PropertyVetoException;
import java.sql.Connection;
import java.sql.SQLException;
import java.text.SimpleDateFormat;

import com.mchange.v2.c3p0.ComboPooledDataSource;
import com.mchange.v2.c3p0.DataSources;

public class TestC3P01 {

/**
* @param args
*/
public static void main(String[] args) {
ComboPooledDataSource cpds = new ComboPooledDataSource();

try {
cpds.setDriverClass( "com.mysql.jdbc.Driver" );
} catch (PropertyVetoException e) {
e.printStackTrace();
System.exit(1);
}
cpds.setJdbcUrl( "jdbc:mysql://127.0.0.1:3306/test" );
cpds.setUser("hb");
cpds.setPassword("123456");
cpds.setMinPoolSize(5);
cpds.setMaxPoolSize(20);
cpds.setInitialPoolSize(10);
cpds.setAcquireRetryAttempts(1);

SimpleDateFormat df = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
Connection[] c = new Connection[20];
for(int i = 0; i < 20; i++) {
try {
System.out.println(df.format(new java.util.Date()));
System.out.println("申请第" + i + "个数据库连接");
c[i] = cpds.getConnection();
System.out.println(df.format(new java.util.Date()));
} catch (SQLException e) {
System.out.println(df.format(new java.util.Date()));
e.printStackTrace();
}
}
try {
System.out.println("超过最大连接数后再次申请数据库连接");
Connection con = cpds.getConnection();
System.out.println(df.format(new java.util.Date()));
} catch (Exception e) {
System.out.println(df.format(new java.util.Date()));
e.printStackTrace();
System.exit(1);
}

try {
DataSources.destroy( cpds );
} catch (SQLException e) {
e.printStackTrace();
}
}

}
...全文
482 4 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
4 条回复
切换为时间正序
请发表友善的回复…
发表回复
热烈的红颜 2012-06-13
  • 打赏
  • 举报
回复
  for(int i = 0; i < 20; i++) {
try {
System.out.println(df.format(new java.util.Date()));
System.out.println("申请第" + i + "个数据库连接");
c[i] = cpds.getConnection();
System.out.println(df.format(new java.util.Date()));
} catch (SQLException e) {
System.out.println(df.format(new java.util.Date()));
e.printStackTrace();
}
}


你都已经拿到了20个了, 但是 你并没有还回到连接池 所以 你再拿就等待了 ,就这样啊!
heavenbirdliao 2012-06-13
  • 打赏
  • 举报
回复
setCheckoutTimeout()能起作用,多谢!
MiceRice 2012-06-12
  • 打赏
  • 举报
回复
当超过最大数以后,连接池就会等待之前申请的连接被释放,如果超过指定时间就会报获取连接超时异常。

这个超时时间,可以用 setCheckoutTimeout() 来进行设置。


最大连接数本来就是控制整个连接池跟数据库之间建立连接的上限,一直持续获取而不close是不对滴。
亲努力啊 2012-06-12
  • 打赏
  • 举报
回复

写个验证获取数据库当前连当超过最大50时抛出异常(不建议这样)
还是检查下那里打开了连接没有关闭

67,550

社区成员

发帖
与我相关
我的任务
社区描述
J2EE只是Java企业应用。我们需要一个跨J2SE/WEB/EJB的微容器,保护我们的业务核心组件(中间件),以延续它的生命力,而不是依赖J2SE/J2EE版本。
社区管理员
  • Java EE
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧