springboot v2.0.3版本多数据源配置
程序员文章站
2022-05-18 17:22:27
本篇分享的是springboot多数据源配置,在从springboot v1.5版本升级到v2.0.3时,发现之前写的多数据源的方式不可用了,捕获错误信息如: 先来说下之前的多数据源配置如: 配置了两个数据库,在原来默认的datasource节点下面增加了seconddatasource节点的配置, ......
本篇分享的是springboot多数据源配置,在从springboot v1.5版本升级到v2.0.3时,发现之前写的多数据源的方式不可用了,捕获错误信息如:
异常:jdbcurl is required with driverclassname.
先来说下之前的多数据源配置如:
1 spring: 2 datasource: 3 url: jdbc:sqlserver://192.168.122.111;databasename=flight 4 username: sa 5 password: 1234.abcd 6 driver-class-name: com.microsoft.sqlserver.jdbc.sqlserverdriver 7 seconddatasource: 8 url: jdbc:sqlserver://192.168.122.111;databasename=flight2 9 username: sa 10 password: 1234.abcd 11 driver-class-name: com.microsoft.sqlserver.jdbc.sqlserverdriver
配置了两个数据库,在原来默认的datasource节点下面增加了seconddatasource节点的配置,然后主要的代码如:
1 @primary 2 @bean 3 @configurationproperties(prefix = "spring.seconddatasource") 4 public datasource datasource() { 5 return datasourcebuilder.create().build(); 6 } 7 8 @bean(name = "secoddatasource") 9 @configurationproperties(prefix = "spring.seconddatasource") 10 public datasource secoddatasource() { 11 return datasourcebuilder.create().build(); 12 } 13 14 @primary 15 @bean 16 public jdbctemplate jdbctemplate(datasource datasource) { 17 return new jdbctemplate(datasource); 18 } 19 20 @bean(name = "secondjdbctemplate") 21 public jdbctemplate secondjdbctemplate(@qualifier(value = "secoddatasource") datasource datasource) { 22 return new jdbctemplate(datasource); 23 }
来创建两个不同的jdbctemplate,到这里老版本这样干没有啥问题,能够正常的得到数据;而升级未v2.03版本的时候提示:异常:jdbcurl is required with
driverclassname.
很显然配置节点不能使用导致的,配置节点名字变了,要解决这问题这里使用了托管datasourceproperties的方式来对数据配置从新赋值,具体代码如:
1 @bean 2 @primary 3 @configurationproperties(prefix = "spring.datasource") 4 public datasourceproperties datasourceproperties(){ 5 return new datasourceproperties(); 6 } 7 8 @bean("secondproperties") 9 @configurationproperties(prefix = "spring.seconddatasource") 10 public datasourceproperties secondproperties(){ 11 return new datasourceproperties(); 12 } 13 14 @primary 15 @bean 16 public datasource datasource(datasourceproperties datasourceproperties) { 17 return datasourceproperties.initializedatasourcebuilder().build(); 18 } 19 20 @bean(name = "secoddatasource") 21 public datasource secoddatasource(@qualifier(value = "secondproperties") datasourceproperties datasourceproperties) { 22 return datasourceproperties.initializedatasourcebuilder().build(); 23 }
能够看出多了一级datasourceproperties的创建,此时能够运行出结果如:
除了编码的这种方式也可以采用上面说的既然是配置找不到,那配置肯定是改名了,根据错误提示我们不放把url改名未jdbc-url,具体如下:
此刻我们再来运行,同样的也能出来数据;两种方式处理v2.03版本数据源问题:
- 编码配置datasourceproperties
- 通过配置jdbc-url
通过数据源配置节点名变动的问题,引发了springboot在升级迭代的过程中一些细微的变动,这或许会给我们在学习和升级过程中造成麻烦,所以官网每次升级的内容说明还是有必要看下的。
上一篇: TypeScript入门解析
推荐阅读
-
SpringBoot整合MyBatisPlus配置动态数据源的方法
-
Springboot+mybatis+druid 配置多数据源
-
SpringBoot Mybatis如何配置多数据源并分包
-
037.[转] springboot 配置多个数据源
-
SpringBoot整合JPA数据源方法及配置解析
-
DB数据源之SpringBoot+MyBatis踏坑过程(二)手工配置数据源与加载Mapper.xml扫描
-
springboot2.3.4版本配置拦截器(不会配的,样式失效的看过来)
-
springboot之多数据源配置JdbcTemplate
-
SpringBoot + MyBatis + Druid连接池配置多数据源
-
Springboot集成通用Mapper与Pagehelper,实现mybatis+Druid的多数据源配置