当前位置: 移动技术网 > IT编程>开发语言>Java > springboot v2.0.3版本多数据源配置

springboot v2.0.3版本多数据源配置

2018年11月09日  | 移动技术网IT编程  | 我要评论

北京木樨园服装批发市场,马云清华演讲,性伦理电影

本篇分享的是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在升级迭代的过程中一些细微的变动,这或许会给我们在学习和升级过程中造成麻烦,所以官网每次升级的内容说明还是有必要看下的。

如对本文有疑问,请在下面进行留言讨论,广大热心网友会与你互动!! 点击进行留言回复

相关文章:

验证码:
移动技术网