lotus

贵有恒何必三更眠五更起 最无益只怕一日曝十日寒

  博客园  :: 首页  :: 新随笔  :: 联系 :: 订阅 订阅  :: 管理

 

转载:https://www.jianshu.com/p/381c86bdbff6

看了看druid和dbcp2的原码,发现他们都有各自存储连接的方式。

druid :

private volatile DruidConnectionHolder[] connections;

dbcp2

private final LinkedBlockingDeque<PooledObject<T>> idleObjects =
        new LinkedBlockingDeque<PooledObject<T>>();

以自己的理解写了个简单的连接池

  • 采用LinkedBlockingQueue管理数据库连接
  • 实现javax.sql.DataSource接口
  • 采用构造者设计模式
  • 通过反射技术获取驱动
  • 兼容MYSQL5与6驱动
  • 支持配置连接池资源消耗殆尽的处理策略
  • 未实现空闲连接数控制

核心源码

  1. 初始化连接池


     

    初始化连接池.png
  2. 获取连接


     

     

    获取连接.png
  3. 释放连接


     

     

    释放连接.png
  4. 使用连接池


     

     

    使用方式.png

github源码地址

ClawDataSource

posted on 2019-07-26 11:25  白露~  阅读(709)  评论(0编辑  收藏  举报