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进行物理连接的关闭。出现以下三种情况时会触发连接的自动关闭:

  1. 连接断开;
  2. 连接存活时间超出最大生存时间(maxLifeTime)
  3. 连接空闲时间超出最大空闲时间(idleTimeout)

closeConnectionExecutor关闭连接后,会调用fillPool()方法对连接池进行连接填充。

同时HikariPool提供evictConnection(Connection)方法对物理连接进行手动关闭。


以下是简要的整理连接变化导向图:

posted on 2017-10-23 17:27  taisenki  阅读(2654)  评论(0编辑  收藏  举报

导航