zoukankan      html  css  js  c++  java
  • 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)方法对物理连接进行手动关闭。


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

  • 相关阅读:
    移位乘除法
    标准C++的一些约定
    图论的一些定义
    二进制取数在多重背包和母函数中的应用
    深入理解最小割的意义
    pku 3020 最小路径覆盖集
    pku 1986 LCA算法的应用
    pku 1185
    连通分量(tarjan算法)
    pku 2983 差分约束系统判断
  • 原文地址:https://www.cnblogs.com/taisenki/p/7717912.html
Copyright © 2011-2022 走看看