Druid连接的创建时点
1. initialSize>0时,将在init()时进行创建,此时创建连接由是否指定asyncInit参数来判断,需要注意的是,此时如果采用异步创建需要设置线程池,否则即使开启asyncInit也依旧会采用同步创建。
2. 开启keepAlive并且initialSize<minIdle,将在init()时进行创建,此时将采用异步方式创建连接
3. 抛弃连接(discardConnection)且连接池中活跃连接总数<最小数量,此时采用异步方式创建连接
4. 连接池取出的连接发生异常且fatalErrorCount - fatalErrorCountLastShrink > onFatalErrorMaxActive时,此时采用异步方式创建
5. 从连接池中取连接时,连接池中没有空闲连接,此时将采用异步方式创建连接
6. 向连接池中置入连接时(要求此时为异步线程池方式创建),且满足poolingCount + createTaskCount < notEmptyWaitThreadCount && activeCount + poolingCount + createTaskCount < maxActive时
7. 连接池收缩(shrink)后,将keepAliveConnections归还至池子中时存在校验异常的连接,并且连接池中活跃连接总数<最小数量,此时采用异步创建
8. 连接池收缩后,开启keepAlive且连接池中活跃连接总数<最小数量,此时将采用异步方式将连接池中连接填充至最小连接数
9. 连接池收缩后,未开启keepAlive或连接池中活跃连接总数>=最小数量,并且满足onFatalError || fatalErrorIncrement > 0,此时将采用异步方式创建连接
10. 获得连接时,满足设置了创建线程池、池中没有连接、活跃连接数<最大活跃数、没有创建中的连接、线程池是ScheduledThreadPoolExecutor或它的子类,且此时线程池中存在排队,同步创建
11. 在手动调用fill()方法时,采用同步方式创建