com.alibaba.druid.pool.GetConnectionTimeoutException: wait millis 60000, active 20, maxActive 20 问题

一、异常现象
com.alibaba.druid.pool.GetConnectionTimeoutException: wait millis 60000, active 20, maxActive 20, creating 0

二、异常描述
从异常现象中 com.alibaba.druid.pool.GetConnectionTimeoutException 可以看到错误信息提示是阿里巴巴Druid数据库连接池的数据库获取连接超时异常原因,具体为 active 20,活动的连接数为20, maxActive 20, 最大的连接数为20, 意思很明显,活动的连接数与最大连接数相同,连接用完了,在等待(我写的配置是60000毫秒即60秒)新的连接,却没有新连接可用,然后超时了。
 

三、问题原因 

1、事务没提交

开启了事务,但是没有关闭事务,导致连接池一直被占用

应该提交事务,释放连接池

2.

Connection conn = null;  PreparedStatement preState = null;
ResultSet rs = null; 是成员变量。

以上三项放在调用sql的方法体内,别用成员变量,用完后立即关闭释放连接池资源,springboot2以上项目建议用HikariCP

2、连接没关闭

打开了数据库连接,没有关闭,连接池被占用。

每次链接使用完毕,当即在方法体内关闭链接,举例如下,放到finally内关闭会遇上该问题,原因不明,但现象如此。所以要直接在try内就关闭。


	public boolean updateState(List<Push000Bean> list) {
		
		StringBuilder sb = new StringBuilder();
		Connection conn = JdbcUtil.getConnection();
		
		PreparedStatement preState = null;
		
		try {
			conn.setAutoCommit(false);
			preState = conn.prepareStatement(updateSql);
			for(Push000Bean pb : list) {
				preState.setString(1, pb.getPhoneNo());
				preState.addBatch();
			}
			preState.executeBatch();
			conn.commit();
			preState.close();        //立刻关闭
			conn.close();            //立刻关闭
		} catch (SQLException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
		
		
		return false;
	}
	

Connection conn = null;
ResultSet rs = null;

PreparedStatement preState = null;

preState = conn.prepareStatement(insertLogSql);

preState.close();

if (rs != null) {
       rs.close();
 }
  if (conn != null) {
       conn.close();
 }

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值