动态数据源的详细执行分析
在上一章节中,讲解了动态数据源对于数据中台项目存在的意义,那么从本章开始将详细的讲解项目中的动态数据源是如何加载并执行的
整体目标与思路
- 核心职责:
AgilityRouteDataSource作为整个应用唯一对外暴露的DataSourceBean,负责在运行时基于上下文选择具体数据源并获取连接;在事务内对同一线程的多数据源连接进行集中管理与提交/回滚。 - 关键配套:
- 属性装配与数据源创建:
AgilityDataSourceProperty→AgilityYamlDataSourceObtain→ 具体数据源实例(Hikari等) - 路由上下文:
AgilityDataSourceHolder(ThreadLocal 栈) - 切换切面:
AgilityDataSourceAspect(@AgilityDataSource) - 事务切面:
AgilityTransactionAspect(@AgilityTransactional) - 事务持有:
TransactionIdHolder(标识事务)与TransactionMultiConnectionHolder(多数据源下的连接复用) - 自动装配:
AgilityDataSourceAutoConfig(将AgilityRouteDataSource注册为主DataSource)
- 属性装配与数据源创建:
一、自动装配:把路由数据源注册为应用主 DataSource
启动时,自动装配类把 “属性解析 → 数据源创建 → 路由数据源” 一条链装起来,并提前于 Spring 默认数据源自动配置执行,保证全局唯一 DataSource 即为“路由数据源”。
@EnableConfigurationProperties(value = AgilityDataSourceProperty.class)
@AutoConfigureBefore(name = "org.springframework.boot.autoconfigure.jdbc.DataSourceAutoConfiguration")
public class AgilityDataSourceAutoConfig {
private final AgilityDataSourceProperty agilityDataSourceProperty;
public AgilityDataSourceAutoConfig(AgilityDataSourceProperty agilityDataSourceProperty) {
this.agilityDataSourceProperty = agilityDataSourceProperty;
}
@ConditionalOnClass(HikariDataSource.class)
@Bean
public DataSourceParse dataSourceParse(){
return new HikariDataSourceParse();
}
@Bean
public DataSourceCreatorHandler dataSourceCreatorHandler(DataSourceParse dataSourceParse){
return new DataSourceCreatorHandler(dataSourceParse);
}
@Bean
public AgilityDataSourceObtain agilityDataSourceObtain(DataSourceCreatorHandler dataSourceCreatorHandler) {
return new AgilityYamlDataSourceObtain(agilityDataSourceProperty.getDataSources(), dataSourceCreatorHandler);
}
@ConditionalOnMissingBean
@Bean
public DataSource agilityRouteDataSource(AgilityDataSourceObtain agilityDataSourceObtain){
return new AgilityRouteDataSource(agilityDataSourceObtain,agilityDataSourceProperty.getMaster());
}
属性模型与数据源创建器:
@Data
@ConfigurationProperties(prefix = AgilityDataSourceProperty.PREFIX)
public class AgilityDataSourceProperty {
public static final String PREFIX = "spring.datasource.agility";
/** 主数据源 */
private String master = DataSourceConstant.MASTER;
/** 所有数据源配置,key 就是 数据库 */
private Map<String, DataSourceProperty> dataSources = new HashMap<>();
@Data
public static class DataSourceProperty {
private Class<? extends DataSource> type;
private String url;
private String username;
private String password;
private String driverClassName;
}
}
@AllArgsConstructor
public class AgilityYamlDataSourceObtain implements AgilityDataSourceObtain {
private final Map<String, DataSourceProperty> dataSourcePropertyMap;
private final DataSourceCreatorHandler dataSourceCreatorHandler;
@Override
public Map<String, DataSource> obtainDataSource() {
Map<String, DataSource> dataSourceMap = MapUtil.newHashMap();
for (Entry<String, DataSourceProperty> entry : dataSourcePropertyMap.entrySet()) {
//规则配置创建具体的数据源
DataSource dataSource = dataSourceCreatorHandler.createDataSource(entry.getValue());
dataSourceMap.put(entry.getKey(), dataSource);
}
return dataSourceMap;
}
}
具体的配置
通过以上的属性和配置,能够将主数据源和其他数据源都会加载到Spring的bean中,SpringBoot中关于动态数据源的配置:
spring:
datasource:
agility:
master: d_collect_data
dataSources:
d_collect_data:
type: com.zaxxer.hikari.HikariDataSource
driver-class-name: com.mysql.cj.jdbc.Driver
url: jdbc:mysql://127.0.0.1:3306/d_collect_data?useUnicode=true&characterEncoding=UTF-8&rewriteBatchedStatements=true&allowMultiQueries=true&serverTimezone=Asia/Shanghai
username: root
password: root
d_record:
type: com.zaxxer.hikari.HikariDataSource
driver-class-name: com.mysql.cj.jdbc.Driver
url: jdbc:mysql://127.0.0.1:3306/d_record?useUnicode=true&characterEncoding=UTF-8&rewriteBatchedStatements=true&allowMultiQueries=true&serverTimezone=Asia/Shanghai
username: root
password: root
二、AgilityRouteDataSource:动态路由与统一入口
AgilityRouteDataSource 实现了 AbstractDataSource 与 SmartDataSource,是全局统一的 DataSource 实例。核心职责有三:
- 启动后集中“加载并缓存所有真实数据源”;
- 运行时“依据上下文选择具体数据源”;
- 事务内“同一数据源连接只创建一次并复用”。
付费内容提示
该文档的全部内容仅对「JavaUp项目实战&技术讲解」知识星球用户开放
加入星球后,你可以获得:
- 超级八股文:100万+字的全栈技术知识库,涵盖技术核心、数据库、中间件、分布式等深度剖析的讲解
- 讲解文档:黑马点评Plus、大麦、大麦pro、大麦AI、流量切换、数据中台的从0到1的550+详细文档
- 讲解视频:黑马点评Plus、大麦、大麦pro、大麦AI、流量切换、数据中台的核心业务详细讲解
- 1 对 1 解答:可以对我进行1对1的问题提问,而不仅仅只限于项目
- 针对性服务:有没理解的地方,文档或者视频还没有讲到可以提出,本人会补充
- 面试与简历指导:提供面试回答技巧,项目怎样写才能在简历中具有独特的亮点
- 中间件环境:对于项目中需要使用的中间件,可直接替换成我提供的云环境
- 面试后复盘:小伙伴去面试后,如果哪里被面试官问住了,可以再找我解答
- 远程的解决:如果在启动项目遇到问题,本人可以帮你远程解决
进入星球后,即可享受上述所有服务,保证不会再有其他隐藏费用。
