Hikaricp源码解读(5)——物理连接生命周期介绍
5、物理连接生命周期介绍
HikariCP中的连接取用流程如下:
其中HikariPool负责对资源连接进行管理,而ConcurrentBag则是作为物理连接的共享资源站,PoolEntry则是对物理连接的1-1封装。
PoolEntry通过borrow方法从bag中取出,之后通过PoolEntry.createProxyConnection调用工厂类生成HikariProxyConnection返回。
HikariProxyConnection调用close方法时调用了PooleEntry的recycle方法,之后通过HikariPool调用了ConcurrentBag的requite放回。(poolEntry通过borrow从bag中取出,再通过requite放回。资源成功回收)。
HikariCP中的连接生成流程如下:
HikariCP中通过独立的线程池addConnectionExecutor进行新连接的生成,连接生成方法为PoolEntryCreator。
物理链接的生成只由PoolBase的newConnection()实现,之后封装成PoolEntry,通过Bag的add方法加入ConcurrentBag。
当ConcurrentBag存在等待线程,或者有连接被关闭时,会触发IBagItemListener的addBagItem(wait)方法,调用PoolEntryCreator进行新连接的生成。
HikariCP中的连接关闭流程如下:
HikariCP中通过独立的线程池closeConnectionExecutor进行物理连接的关闭。出现以下三种情况时会触发连接的自动关闭:
- 连接断开;
- 连接存活时间超出最大生存时间(maxLifeTime)
- 连接空闲时间超出最大空闲时间(idleTimeout)
closeConnectionExecutor关闭连接后,会调用fillPool()方法对连接池进行连接填充。
同时HikariPool提供evictConnection(Connection)方法对物理连接进行手动关闭。
以下是简要的整理连接变化导向图: