druid1.2.8源码阅读:第九天

本文详细介绍了Druid1.2.8版本中DestroyTask线程的工作流程,该线程负责检查并关闭连接池中不再可用的连接。首先,线程会获取锁并判断是否已初始化。接着,遍历keepAliveConnections数组,校验每个连接的可用性,将可用的连接放回连接池,不可用的则关闭。此外,当连接池中连接加上活动连接数小于最小空闲连接数(minIdle)时,线程会触发填充操作。通过这种方式,Druid确保了连接池的健康运行和资源的有效利用。

druid1.2.8源码阅读:第九天

一、DestroyTask线程

第一步: 获取锁

try {
    lock.lockInterruptibly();
} catch (InterruptedException e) {
    return;
}
 

第二步:判断有没有初始化

if (!inited) {
    return;
}

keepAliveCount连接:

if (keepAliveCount > 0) {
    // keep order
    for (int i = keepAliveCount - 1; i >= 0; --i) {
        DruidConnectionHolder holer = keepAliveConnections[i];
        Connection connection = holer.getConnection();
        holer.incrementKeepAliveCheckCount();

        boolean validate = false;
        //校验连接是否还可用
        try {
            this.validateConnection(connection);
            validate = true;
        } catch (Throwable error) {
            if (LOG.isDebugEnabled()) {
                LOG.debug("keepAliveErr", error);
            }
            // skip
        }

        boolean discard = !validate;
        //如果可用,则直接put到connections中,放置到尾部。
        if (validate) {
            holer.lastKeepTimeMillis = System.currentTimeMillis();
            boolean putOk = put(holer, 0L, true);
            if (!putOk) {
                discard = true;
            }
        }
		
		//如果不可用,则关闭连接
        if (discard) {
            try {
                connection.close();
            } catch (Exception e) {
                // skip
            }

            lock.lock();
            //加锁更新计数器
            try {
                discardCount++;

                if (activeCount + poolingCount <= minIdle) {
                    emptySignal();
                }
            } finally {
                lock.unlock();
            }
        }
    }
    this.getDataSourceStat().addKeepAliveCheckCount(keepAliveCount);
    Arrays.fill(keepAliveConnections, null);
}

对于keepalive状态的连接,当连接状态可用的时候,放回连接池。

另一种情况:连接不够用,并且连接池不满:

//keepAlive状态,且连接池中的连接加上被使用的连接仍然小于minIdle
if (keepAlive && poolingCount + activeCount < minIdle) {
    needFill = true;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值