Spring多个数据源配置详解
前言
在上篇文章讲到了如何配置单数据源,但是在实际场景中,会有需要配置多个数据源的场景,比如说,我们在支付系统中,单笔操作(包含查询、插入、新增)中需要操作主库,在批量查询或者对账单查询等对实时性要求不高的场景,需要使用读库来操作,依次来减轻数据库的压力。那么我们如何配置多数据源?
这里还是基于springboot应用的情况下,我们看一下怎么配置。
因为SpringBoot会实现自动配置,但是SpringBoot并不知道我们的业务场景分别要使用哪一个数据源,因此我们需要把相关的自动配置关闭。
首先,生成项目骨架,引入相应的依赖
org.springframework.boot spring-boot-starter-jdbcorg.springframework.boot spring-boot-starter-actuatororg.springframework.boot spring-boot-starter-webcom.h2database h2runtimeorg.projectlombok lomboktrue ```**然后,在Application排除自动装配类**```java@SpringBootApplication(exclude = { DataSourceAutoConfiguration.class,DataSourceTransactionManagerAutoConfiguration.class,JdbcTemplateAutoConfiguration.class})@Slf4jpublic class MultiDataSourceDemoApplication {} org.springframework.boot spring-boot-starter-testtest
上面代码中,我们排除了DataSourceAutoConfiguration、DataSourceTransactionManagerAutoConfiguration、JdbcTemplateAutoConfiguration三个类,然后就可以自己定义DataSource了。
【Spring多个数据源配置详解】配置数据源
//第一个数据源 @Bean @ConfigurationProperties("first.datasource") public DataSource firstDataSource() {return DataSourceBuilder.create().build(); } @Bean public JdbcTemplate firstJdbcTemplate() {return new JdbcTemplate(firstDataSource()); } @Bean @Resource public PlatformTransactionManager firstTxManager(DataSource firstDataSource) {return new DataSourceTransactionManager(firstDataSource); } //第二个数据源 @Bean @ConfigurationProperties("second.datasource") public DataSource secondDataSource() {return DataSourceBuilder.create().build(); } @Bean public JdbcTemplate secondJdbcTemplate() {return new JdbcTemplate(secondDataSource()); } @Bean @Resource public PlatformTransactionManager secondTxManager(DataSource secondDataSource) {return new DataSourceTransactionManager(secondDataSource); }
application.properties的配置项信息
management.endpoints.web.exposure.include=*spring.output.ansi.enabled=ALWAYSfirst.datasource.jdbc-url=jdbc:mysql://localhost:3306/firstfirst.datasource.username=rootfirst.datasource.password=xxxsecond.datasource.jdbc-url=jdbc:mysql://localhost:3306/secondsecond.datasource.username=rootsecond.datasource.password=xxx
看一下表结构和数据
文章图片
文章图片
运行测试代码:
@Test public void testMutilDataSource(){firstJdbcTemplate.queryForList("SELECT * FROM test1").forEach(row -> log.info("记录:"+row.toString())); secondJdbcTemplate.queryForList("SELECT * FROM test2").forEach(row -> log.info("记录:"+row.toString())); }
我们看一下运行效果:
文章图片
我们可以看到,两个数据源都初始化成功了,并且各自数据源执行的结果准确。
上面的方式没有集成Mybatis,使用的是jdbcTemplate,网络上还有很多配置方式,比如动态选择数据源,大同小异,不过笔者还是建议不同的业务单独指定数据源,容易维护。
我们已经演示了简单的单数据源和多数据源的配置方式,我们下一篇文章将讲一下,SpringBoot默认的连接池HikariCP。
到此这篇关于Spring多个数据源配置详解的文章就介绍到这了,更多相关Spring多数据源配置内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
推荐阅读
- Activiti(一)SpringBoot2集成Activiti6
- SpringBoot调用公共模块的自定义注解失效的解决
- 解决SpringBoot引用别的模块无法注入的问题
- 2018-07-09|2018-07-09 Spring 的DBCP,c3p0
- Android|Android install 多个设备时指定设备
- spring|spring boot项目启动websocket
- Spring|Spring Boot 整合 Activiti6.0.0
- Spring集成|Spring集成 Mina
- springboot使用redis缓存
- Spring|Spring 框架之 AOP 原理剖析已经出炉!!!预定的童鞋可以识别下发二维码去看了