Alibaba Druid 源码阅读(五)数据库连接池 连接关闭探索
简介
在上文中探索了数据库连接池的获取,下面接着初步来探索下数据库连接的关闭,看看其中具体执行了那些操作
连接关闭
下面的具体的代码,相关的位置,加上了自己的注释:
@Override
public void close() throws SQLException {
// 下面两段检查避免重复关闭
if (this.disable) {
return;
}
DruidConnectionHolder holder = this.holder;
if (holder == null) {
if (dupCloseLogEnable) {
LOG.error("dup close");
}
return;
}
// 判断是否是一样的线程,不是则使用异步关闭
DruidAbstractDataSource dataSource = holder.getDataSource();
boolean isSameThread = this.getOwnerThread() == Thread.currentThread();
if (!isSameThread) {
dataSource.setAsyncCloseConnectionEnable(true);
}
if (dataSource.isAsyncCloseConnectionEnable()) {
syncClose();
return;
}
if (!CLOSING_UPDATER.compareAndSet(this, 0, 1)) {
return;
}
try {
// 连接关闭时的一些增强?
for (ConnectionEventListener listener : holder.getConnectionEventListeners()) {
listener.connectionClosed(new ConnectionEvent(this));
}
// Filter也能作用到连接关闭时?
List<Filter> filters = dataSource.getProxyFilters();
if (filters.size() > 0) {
FilterChainImpl filterChain = new FilterChainImpl(dataSource

本文深入探讨了Alibaba Druid数据库连接池中连接关闭的过程,分析了关闭操作的同步和异步机制,并指出在特定条件下,连接会被关闭还是返回到连接池。
最低0.47元/天 解锁文章
2806

被折叠的 条评论
为什么被折叠?



