“多态”的数据库连接池实现
需求
数据库连接的池化管理
支持不同数据源链接池化处理
问题
如何维护链接对象
如何区分不同数据源池化
如何实现资源同步问题
分析
如何维护对象
使用阻塞队列实现对象存储,数据结构采用LinkedBlockingDeque(同步集合,内部线程序安全)。
如何区分不同数据源池化
即席查询中,针对不同的数据库链接,会创建不同的的数据库链接对象(connection 是线程不安全的)。为了保证安全,可以使用ThreadLocal来维护。不同的connection要缓存,并且在空闲时可以复用。内部使用数据结构ConcurrentHashMap同步集合map来维护不同数据源链接。
如何实现同步
如上,使用同步集合实现共享资源(数据库链接connection)的线程安全。
实现
思路
涉及到资源的创建,释放等。最初,依据自己的方式实现。发现底层需要考虑的同步,以及淘汰策略问题。写了个雏形,感觉不满意。于是,想到apache有一个专门的对象池处理组件。common-pool2。然后,查阅了相关资料。果然满足底层需求。其中相关组件介绍,这里不展开。common-pool2对象池(连接池)的介绍及使用,这篇文章将各组件介绍的比较详细,可参考。redis的java实现jedis底层就是借用commons-pool2实现的。
然后,使用文中介绍的GenericKeyedObjectPool,其内部就是一组k-v模型。刚好满足本文需求,实现不同数据源链接池化处理。
设计
类图
ConnectionConfig:数据链接配置
ConnectionPoolConfig:数据库连接池配置
ConnectionFactory:数据库链接
ConnectionPool:数据库连接池
ConnectionProvider:数据库链接接口
ConnectionProviderImpl:数据库链接实现
源码地址:
https://github.com/alanzhang211/common-db-pool
动动小手指,关注一下,是给予我最大的动力。
- Java 一步一步实现高逼格的字符串替换工具(一)
- Python编写渗透工具学习笔记一 | 0x05抓取应用的banner --推断服务
- Logback 简明使用手册
- Python编写渗透工具学习笔记一 | 0x06 Zip包破解程序
- Java 并发排序
- Python编写渗透工具学习笔记一 | 0x07 Python实现键盘记录器
- Python编写渗透工具学习笔记一 | 0x08字典生成程序
- 漫步VR——Unity语音聊天室开发
- Python编写渗透工具学习笔记一 | 0x01 目录扫描程序
- JDK容器学习之HashMap (一) : 底层存储结构分析
- Python编写渗透工具学习笔记一 | 0x02实现一个反弹shell
- 动手实现MVC: 1. Java 扫描并加载包路径下class文件
- 动手实现MVC: 2. bean加载, IoC依赖注入
- Python编写渗透工具学习笔记一 | 0x04 nmap实现端口扫描(准确性更高)
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- R语言中ARMA,ARIMA(Box-Jenkins),SARIMA和ARIMAX模型用于预测时间序列数据
- 以图搜图系统工程实践
- R语言线性判别分析(LDA),二次判别分析(QDA)和正则判别分析(RDA)
- 用R语言实现神经网络预测股票实例
- R语言社区主题检测算法应用案例
- C++ vector学习笔记
- 锂电池充电慢?手把手教你制作锂电池快充充电器
- c++ cin, get学习笔记
- c++ sort 学习笔记
- CSS3 引入方式 注释 颜色属性 学习笔记
- 使用 Makefile 构建指令集
- 安卓 App 逆向课程之四 frida 注入 Okhttp 抓包中篇
- NumPy进阶修炼80题|41-60
- 时序数据库 InfluxDB(一)
- Netty一文深入