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)方法对物理连接进行手动关闭。


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

  • 相关阅读:
    ThinkPHP模版验证要注意的地方
    js关闭子页面刷新父页面
    js替换字符指定字符方法
    Ubuntu安装后的一些配置
    Docker入门
    RabbitMQ 基本概念和使用
    JAX-WS注解
    Linux 常用命令
    ubuntu16.04 搭建 Mysql服务器
    ubuntu 安装 Tomcat
  • 原文地址:https://www.cnblogs.com/taisenki/p/7717912.html
Copyright © 2011-2022 走看看