本篇分享的是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的创建,此时能够运行出结果如:
除了编码的这种方式也可以采用上面说的既然是配置找不到,那配置肯定是改名了,根据错误提示我们不放把url改名未jdbc-url,具体如下:
此刻我们再来运行,同样的也能出来数据;两种方式处理v2.03版本数据源问题:
•编码配置datasourceproperties
•通过配置jdbc-url
通过数据源配置节点名变动的问题,引发了springboot在升级迭代的过程中一些细微的变动,这或许会给我们在学习和升级过程中造成麻烦,所以官网每次升级的内容说明还是有必要看下的。
总结
以上所述是小编给大家介绍的springboot v2.0.3版本多数据源配置方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对快网idc网站的支持!
原文链接:https://www.cnblogs.com/wangrudong003/archive/2018/11/09/9933162.html
相关文章
- 64M VPS建站:能否支持高流量网站运行? 2025-06-10
- 64M VPS建站:怎样选择合适的域名和SSL证书? 2025-06-10
- 64M VPS建站:怎样优化以提高网站加载速度? 2025-06-10
- 64M VPS建站:是否适合初学者操作和管理? 2025-06-10
- ASP.NET自助建站系统中的用户注册和登录功能定制方法 2025-06-10
- 2025-07-10 怎样使用阿里云的安全工具进行服务器漏洞扫描和修复?
- 2025-07-10 怎样使用命令行工具优化Linux云服务器的Ping性能?
- 2025-07-10 怎样使用Xshell连接华为云服务器,实现高效远程管理?
- 2025-07-10 怎样利用云服务器D盘搭建稳定、高效的网站托管环境?
- 2025-07-10 怎样使用阿里云的安全组功能来增强服务器防火墙的安全性?
快网idc优惠网
QQ交流群
-
2025-06-04 49
-
2025-05-29 46
-
2025-05-29 17
-
2025-05-29 49
-
2025-05-27 27