springboot v2.0.3版本多数据源配置
2024-10-09 04:59:31
本篇分享的是springboot多数据源配置,在从springboot v1.5版本升级到v2.0.3时,发现之前写的多数据源的方式不可用了,捕获错误信息如:
异常:jdbcUrl is required with driverClassName.
先来说下之前的多数据源配置如:
spring:
datasource:
url: jdbc:sqlserver://192.168.122.111;DatabaseName=flight
username: sa
password: .abcd
driver-class-name: com.microsoft.sqlserver.jdbc.SQLServerDriver
seconddatasource:
url: jdbc:sqlserver://192.168.122.111;DatabaseName=flight2
username: sa
password: .abcd
driver-class-name: com.microsoft.sqlserver.jdbc.SQLServerDriver
配置了两个数据库,在原来默认的datasource节点下面增加了seconddatasource节点的配置,然后主要的代码如:
@Primary
@Bean
@ConfigurationProperties(prefix = "spring.seconddatasource")
public DataSource dataSource() {
return DataSourceBuilder.create().build();
} @Bean(name = "secodDataSource")
@ConfigurationProperties(prefix = "spring.seconddatasource")
public DataSource secodDataSource() {
return DataSourceBuilder.create().build();
} @Primary
@Bean
public JdbcTemplate jdbcTemplate(DataSource dataSource) {
return new JdbcTemplate(dataSource);
} @Bean(name = "secondJdbcTemplate")
public JdbcTemplate secondJdbcTemplate(@Qualifier(value = "secodDataSource") DataSource dataSource) {
return new JdbcTemplate(dataSource);
}
来创建两个不同的jdbctemplate,到这里老版本这样干没有啥问题,能够正常的得到数据;而升级未V2.03版本的时候提示:异常:jdbcUrl is required with
driverClassName.
很显然配置节点不能使用导致的,配置节点名字变了,要解决这问题这里使用了托管DataSourceProperties的方式来对数据配置从新赋值,具体代码如:
@Bean
@Primary
@ConfigurationProperties(prefix = "spring.datasource")
public DataSourceProperties dataSourceProperties(){
return new DataSourceProperties();
} @Bean("secondProperties")
@ConfigurationProperties(prefix = "spring.seconddatasource")
public DataSourceProperties secondProperties(){
return new DataSourceProperties();
} @Primary
@Bean
public DataSource dataSource(DataSourceProperties dataSourceProperties) {
return dataSourceProperties.initializeDataSourceBuilder().build();
} @Bean(name = "secodDataSource")
public DataSource secodDataSource(@Qualifier(value = "secondProperties") DataSourceProperties dataSourceProperties) {
return dataSourceProperties.initializeDataSourceBuilder().build();
}
能够看出多了一级DataSourceProperties的创建,此时能够运行出结果如:
除了编码的这种方式也可以采用上面说的既然是配置找不到,那配置肯定是改名了,根据错误提示我们不放把url改名未jdbc-url,具体如下:
此刻我们再来运行,同样的也能出来数据;两种方式处理v2.03版本数据源问题:
- 编码配置DataSourceProperties
- 通过配置jdbc-url
通过数据源配置节点名变动的问题,引发了springboot在升级迭代的过程中一些细微的变动,这或许会给我们在学习和升级过程中造成麻烦,所以官网每次升级的内容说明还是有必要看下的。
最新文章
- web安全浅析
- hadoop分布式存储(1)-hadoop基础概念(毕业设计)
- Kafka设计解析(三)- Kafka High Availability (下)
- thinkphp3.2与phpexcel基础生成
- 【多线程】Future和FutureTask以及CompletionService
- Leetcode#73 Set Matrix Zeroes
- document.write() 和 document.writeln() 区别
- 一元云购完整源码 云购CMS系统 带安卓和ios手机客户端
- 【转】Service Intent must be explicit的解决方法
- Amzon MWS API开发之 上传数据
- java 垃圾回收总结(可达性分析 引用分类
- Weex 初探
- EasyMall注册功能
- LINUX系统软件安装和卸载的常见方法
- 【数学建模】day02-整数规划
- 盛最多水的容器(java实现)
- Android popupMenu
- 20155331 2016-2017-2 《Java程序设计》第七周学习总结
- Nginx技术研究系列1-通过应用场景看Nginx的反向代理
- const修饰函数
热门文章
- 9.app后端选择什么服务器
- kafka实战
- yum安装指定版本的软件包的方法
- 在本地没有安装Oracle的情况下,使用plsql远程连接数据库
- fasthttp 文档手册
- BZOJ_1009_[HNOI2008]GT考试_KMP+矩阵乘法
- BZOJ_2594_[Wc2006]水管局长数据加强版_LCT
- iOS 支付(含支付宝、银联、微信)
- Java基础-单列设计模式
- sum() 函数性能堪忧,列表降维有何良方?