1. 概述

Druid是阿里提供的一个高效的数据库连接池,它可以方便的管理数据库连接,实现连接复用。Druid具有良好的可扩展性,支持SQL检查、慢查询统计等功能。

主流连接池各项功能对比如下:

Druid数据库连接池解析

2. 连接池获取

Druid数据库连接池解析

Druid连接池的模式是采用生产者-消费者模式,使用ReentrantLock进行同步。连接产生获取使用异步方式,提交CreateConnectionTask任务创建连接。

在init()方法中会启动3个线程:

  • LogStatsThread:间隔打印连接池运行状态
  • CreateConnectionThread:异步创建连接池,通过await()/signal()调度
  • DestroyConnectionThread:调用shrink()清理长久为使用的连接,检查连接池连接是否存活状态。

Druid数据库连接池解析

FilterChainImpl类抽象了一个调用链,调用链实现了Filter的链式调用,以及连接调用链代理类。

3. 连接池归还

Druid数据库连接池解析

DruidPooledConnection关闭连接,会将连接归还连接池。

相关文章: