1. 概述
Druid是阿里提供的一个高效的数据库连接池,它可以方便的管理数据库连接,实现连接复用。Druid具有良好的可扩展性,支持SQL检查、慢查询统计等功能。
主流连接池各项功能对比如下:

2. 连接池获取
Druid连接池的模式是采用生产者-消费者模式,使用ReentrantLock进行同步。连接产生获取使用异步方式,提交CreateConnectionTask任务创建连接。
在init()方法中会启动3个线程:
- LogStatsThread:间隔打印连接池运行状态
- CreateConnectionThread:异步创建连接池,通过await()/signal()调度
- DestroyConnectionThread:调用shrink()清理长久为使用的连接,检查连接池连接是否存活状态。
FilterChainImpl类抽象了一个调用链,调用链实现了Filter的链式调用,以及连接调用链代理类。
3. 连接池归还
DruidPooledConnection关闭连接,会将连接归还连接池。