【Spring事物三千问】DataSource的设计和常用实现——Hikari、Druid

news2024/11/19 1:33:10

javax.sql.DataSource

javax.sql.DataSource 是 jdk 提供的接口,各个连接池厂商 和 Spring 都对 DataSource 进行了设计和实现。
javax.sql.DataSource 是连接到物理数据源的工厂接口。它是 java.sql.DriverManager 功能的替代者,是获取数据库连接的首选方法。
DataSource 数据源在必要时可以修改它的属性。例如,如果将数据源移动到其他服务器,则可以更改 DataSource 的属性,这样访问该数据源的代码不需要做任何更改就可以获取到达到目的。
有些 DataSource 的连接池实现还可以支持部分属性在程序运行期间进行修改。

最原始的获取 DB 连接的方法是使用 java.sql.DriverManager#getConnection() 来获取连接。
现在都推荐使用 javax.sql.DataSource#getConnection() 来获取连接。

Spring 对 DataSource 的封装

类图如下:
DataSource.png

图中列出了 DataSource 的三个典型的实现类: HikariDataSource、DruidDataSource 和 AbstractRoutingDataSource

HikariDataSource

HikariDataSource 是 SpringBoot 默认使用的连接池,而且代码量是很少的。
连接池相关的配置参数是放在父类 HikariConfig 中的。

HikariConfig.png

Hikari 连接池的参数分成了两类:一类是可以在运行期间动态修改的;一类是在运行期间不可修改的。
配置项的说明可以参考:
https://github.com/brettwooldridge/HikariCP
https://pdai.tech/md/spring/springboot/springboot-x-mysql-HikariCP.html

关于 connectionTestQuery 参数

connectionTestQuery 参数的作用是:
在一个连接从连接池中拿出来之前,会优先执行 connectionTestQuery 指定的查询语句,从而验证这个连接是存活且有效的。

如果驱动程序支持 JDBC4,那么强烈建议不要设置此属性。
connectionTestQuery 参数是针对不支持 JDBC4 的 Connection#isValid() API 接口的“传统”驱动程序的。
如果没有设置 connectionTestQuery,且驱动程序不支持 JDBC4,那么 HikariCP 将记录一个错误。

DruidDataSource

Druid 连接池是阿里巴巴开源的数据库连接池。Druid 连接池是以监控为主的连接池。
Druid 的配置参数有很多,大致分为了三类:JDBC配置;连接池配置;监控配置

DruidConfig.png

配置说明可以参考:
https://github.com/alibaba/druid/tree/master/druid-spring-boot-starter
https://pdai.tech/md/spring/springboot/springboot-x-mysql-druid.html
https://github.com/alibaba/druid/wiki/DruidDataSource配置属性列表

AbstractRoutingDataSource

AbstractRoutingDataSource 是 Spring 对 DataSource 的抽象实现。它是一个基于 lookup key ,将 DataSource#getConnection() 的调用路由到目标数据源的抽象数据源实现。
通常都是通过 ThreadLocal 绑定的事务上下文变量来确定路由到哪个目标数据源。

IsolationLevelDataSourceRouter 是 AbstractRoutingDataSource 的实现类,它是一个能基于当前事务隔离级别路由到目标数据源的 DataSource 数据源。

举一反三:多数据源配置的思考

结合前面对 多事物管理器和多数据源处理 的分析,以及上面对 AbstractRoutingDataSource 特性的讲解,我们可以发现,多数据源的切换可以通过两种方式来实现:

1、静态多数据源的方式来配置

  • 首先,配置多个 DataSource
  • 然后,配置多个 SqlSessionFactory。
    当然,这些 SqlSessionFactory 都是基于上面的 DataSource 来配置的,这样就可以通过 MyBatis 的 Mapper 接口来组装 sql 操作 DB 了。

很显然,这种方式比较适合异构的数据源,即每个数据源中的表都是不一样的,这样定义出来的 MyBatis 的 Mapper 接口也不一样。
那如果是分库分表的数据源(或者主从结构的数据源),这类数据源中的表的结构都是一样的,如果也使用这种静态多数据源的方式来配置的话,就需要定义多个一模一样的 Mapper 接口,这样就会显得冗余且不太优雅。

2、动态多数据源切换的方式

基于 AbstractRoutingDataSource 来进行数据源的切换。

动态数据源的切换可以通过自定义注解的方式,对方法打标记来实现,这里对具体的实现方式不做展开

很显然,这种方式就比较适合分库分表的数据源(或者主从结构的数据源),定义一套 MyBatis 的 Mapper 接口就可以操作多个数据源了。

小结

javax.sql.DataSource 是连接到物理数据源的工厂接口。它是 java.sql.DriverManager 功能的替代者,是获取数据库连接的首选方法。

DataSource 三个典型的实现类: HikariDataSource、DruidDataSource 和 AbstractRoutingDataSource

  • HikariDataSource: SpringBoot 默认使用的数据源实现
  • DruidDataSource: 阿里 Druid 连接池使用的数据源实现
  • AbstractRoutingDataSource: Spring 抽象出来的可动态路由的数据源实现

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/398146.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

H5视频付费点播打赏影视系统程序全开源运营版,含完整的前后台+数据库

源码介绍: 这是一个非常棒的精品代码,之前官方网站售价可是超过2w的。我拿过来了简单测试了一下,完美。好久没有遇到这么好的代码了,特此整理了一份完整的搭建教程并分享一下。 thinkphp开发,前后端分离设计&#xf…

Vue3做出B站【bilibili】 Vue3+TypeScript+ant-design-vue【快速入门一篇文章精通系列(一)前端项目案例】

本项目分为二部分 1、后台管理系统(用户管理,角色管理,视频管理等) 2、客户端(登录注册、发布视频) Vue3做出B站【bilibili】 Vue3TypeScriptant-design-vue【快速入门一篇文章精通系列(一&…

ASEMI高压MOS管20N60参数,20N60尺寸,20N60体积

编辑-Z ASEMI高压MOS管20N60参数: 型号:20N60 漏极-源极电压(VDS):600V 栅源电压(VGS):30V 漏极电流(ID):20A 功耗(PD&#xff…

项目最后一刻发生范围变更该怎么处理?

不管是项目需求发生了变化,还是第一轮可交付成果没有完全达到预期,在项目范围定义的初始阶段之后可能发生变化的原因有很多。当这种情况发生时,你需要准备好一个计划来处理最后一刻的范围变更和调整。 什么是范围变更? 范围变更是…

浪潮 KaiwuDB x 山东重工 | 打造离散制造业 IIoT 标杆解决方案

近日,浪潮 KaiwuDB 携手山东重工集团有限公司(以下简称:山东重工)重磅发布“离散制造业 IIoT 解决方案”。该 IIoT 方案以 KaiwuDB 就地运算专利技术为底座,搭建了”多快优智”的“13N”方案体系,目前已率先…

南京、西安集成电路企业和高校分布一览(附产业链主要厂商及高校名录)

前言 3月2日,国务院副总理刘鹤在北京调研集成电路企业发展,并主持召开座谈会。刘鹤指出,集成电路是现代化产业体系的核心枢纽,关系国家安全和中国式现代化进程。他表示,我国已形成较完整的集成电路产业链,也…

视频理解论文串讲——学习笔记

文章目录DeepVideoTwo-StreamBeyond-short-SmippetsConvolutional FusionTSNC3DI3DNon-localR(21)DSlowFastTimesformer本文是对视频理解领域论文串讲的笔记记录。 一篇相关综述:Yi Zhu, Xinyu Li, Chunhui Liu, Mohammadreza Zolfaghari, Yu…

【YOLO】YOLOv8训练自定义数据集

1. 运行环境 windows11 和 Ubuntu20.04(建议使用 Linux 系统) 首先切换到自己建立的虚拟环境安装 pytorch torch 1.12.0cu116(根据自身设备而定) torchvision 0.13.0cu116(根据自身设备而定&…

详解JAVA枚举类

目录 1.概述 2.常用API 2.1.清单 2.2.代码示例 2.2.1.ordinal 2.2.2.compareTo 2.2.3.toString 2.2.4.valueOf 2.2.5.values 3.成员变量和带参构造 1.概述 枚举变量指的是变量的取值只在一个有限的集合内,如性别、星期几、颜色等。从JDK5开始&#xff0…

超详细CentOS7 NAT模式(有图形化界面)网络配置

在此附上CentOS7(有可视化界面版)安装教程 超详细VMware CentOS7(有可视化界面版)安装教程 打开VMware—>点击编辑---->选择虚拟网络编辑器 打开虚拟网络编辑器后如下图所示: 从下图中我们看到最下面子网IP为…

软测入门(九)unit test

unit test 核心概念 TestCase:测试用例:用类的方式 组织对一个功能的多项测试Fixture : 夹具,用来固定测试环境TestSuite:测试套件:组织多个TestCaseTestRunner:测试执行:用来执行TestSuit,可以导出测试结果 入门 类需要继承unittest.Tes…

ENVI IDL学习笔记之基本操作

前言ENVI IDL(交互式数据语言)是一个通用的科学计算包,它提供了一套数学函数、数据分析工具,以及一些科学可视化和动画工具。IDL 是 ENVI 图像处理和分析软件的基础,可用于编写脚本并自动执行许多使用 ENVI 图形用户界…

【鲁棒优化】基于联合聚类和定价的鲁棒功率控制方法(Matlab代码实现)

💥💥💞💞欢迎来到本博客❤️❤️💥💥 🏆博主优势:🌞🌞🌞博客内容尽量做到思维缜密,逻辑清晰,为了方便读者。 ⛳️座右铭&a…

12接口扩展无忧,存储显示充电都拉满,ORICO XDR扩展坞上手

扩展坞现在很多朋友都用,一般是配合笔记本使用,有些带有桌面模式的手机、平板装上扩展坞之后,也可以变身全能型的办公设备。现在市面上的扩展坞选择不少,我目前用的是一款功能比较全的12合1扩展坞,来自国产品牌ORICO。…

【机会约束、鲁棒优化】具有排放感知型经济调度中机会约束和鲁棒优化研究【IEEE6节点、IEEE118节点算例】(Matlab代码实现)

💥💥💞💞欢迎来到本博客❤️❤️💥💥 🏆博主优势:🌞🌞🌞博客内容尽量做到思维缜密,逻辑清晰,为了方便读者。 ⛳️座右铭&a…

Django/Vue实现在线考试系统-03-开发环境搭建-MySQL安装

1.概述 MySQL是一种关系型数据库管理系统,所使用的 SQL 语言是用于访问数据库的最常用标准化语言。MySQL 软件采用了双授权政策,分为社区版和商业版,由于其体积小、速度快、总体拥有成本低,尤其是开放源码这一特点,一般中小型和大型网站的开发都选择 MySQL 作为网站数据库…

Redis的持久化操作

目录 介绍 RDB(redis database) 是什么 备份如何执行 配置 优势 劣势 备份恢复 AOF(Append Only File) 是什么 数据恢复 正常恢复 异常恢复 同步频率设置 重写(压缩) 持久化流程 优势 劣势 总结 介绍 redis持久化操作方式有两种:RDB和AOF。 RDB(redis database) 是…

mysql数据库之触发器

触发器是与表有关的数据库对象,指在insert、update、delete之前或之后,触发并执行触发器中定义的SQL语句集合。触发器的这种特性可以协助应用在数据库端确保数据的完整性,日志记录,数据校验等操作。 使用别名old和new来引用触发器…

华为OD机试题,用 Java 解【子序列长度】问题

华为Od必看系列 华为OD机试 全流程解析+经验分享,题型分享,防作弊指南)华为od机试,独家整理 已参加机试人员的实战技巧华为od 2023 | 什么是华为od,od 薪资待遇,od机试题清单华为OD机试真题大全,用 Python 解华为机试题 | 机试宝典使用说明 参加华为od机试,一定要注意不…

力扣第99场双周赛题目记录(复盘)

第一题 2578.最小和分割 给你一个正整数 num ,请你将它分割成两个非负整数 num1 和 num2 ,满足: num1 和 num2 直接连起来,得到 num 各数位的一个排列。 换句话说,num1 和 num2 中所有数字出现的次数之和等于 num 中所…