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

2025-05-29 0 33

本篇分享的是springboot多数据源配置,在从springboot v1.5版本升级到v2.0.3时,发现之前写的多数据源的方式不可用了,捕获错误信息如:

异常:jdbcurl is required with driverclassname.

先来说下之前的多数据源配置如:

?

1

2

3

4

5

6

7

8

9

10

11
spring:

datasource:

url: jdbc:sqlserver://192.168.122.111;databasename=flight

username: sa

password: 1234.abcd

driver-class-name: com.microsoft.sqlserver.jdbc.sqlserverdriver

seconddatasource:

url: jdbc:sqlserver://192.168.122.111;databasename=flight2

username: sa

password: 1234.abcd

driver-class-name: com.microsoft.sqlserver.jdbc.sqlserverdriver

配置了两个数据库,在原来默认的datasource节点下面增加了seconddatasource节点的配置,然后主要的代码如:

?

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23
@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的方式来对数据配置从新赋值,具体代码如:

?

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23
@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的创建,此时能够运行出结果如:

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

除了编码的这种方式也可以采用上面说的既然是配置找不到,那配置肯定是改名了,根据错误提示我们不放把url改名未jdbc-url,具体如下:

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

此刻我们再来运行,同样的也能出来数据;两种方式处理v2.03版本数据源问题:

•编码配置datasourceproperties
•通过配置jdbc-url

通过数据源配置节点名变动的问题,引发了springboot在升级迭代的过程中一些细微的变动,这或许会给我们在学习和升级过程中造成麻烦,所以官网每次升级的内容说明还是有必要看下的。

总结

以上所述是小编给大家介绍的springboot v2.0.3版本多数据源配置方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对快网idc网站的支持!

原文链接:https://www.cnblogs.com/wangrudong003/archive/2018/11/09/9933162.html

收藏 (0) 打赏

感谢您的支持,我会继续努力的!

打开微信/支付宝扫一扫,即可进行扫码打赏哦,分享从这里开始,精彩与您同在
点赞 (0)

声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。

快网idc优惠网 建站教程 springboot v2.0.3版本多数据源配置方法 https://www.kuaiidc.com/110281.html

相关文章

发表评论
暂无评论