springboot v2.0.3版本多数据源配置
2018-11-09 02:38:40来源:博客园 阅读 ()
本篇分享的是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在升级迭代的过程中一些细微的变动,这或许会给我们在学习和升级过程中造成麻烦,所以官网每次升级的内容说明还是有必要看下的。
标签:
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有
- springboot2配置JavaMelody与springMVC配置JavaMelody 2020-06-11
- SpringBoot 2.3 整合最新版 ShardingJdbc + Druid + MyBatis 2020-06-11
- 掌握SpringBoot-2.3的容器探针:实战篇 2020-06-11
- nacos~配置中心功能~springboot的支持 2020-06-10
- SpringBoot + Vue + ElementUI 实现后台管理系统模板 -- 后 2020-06-10
IDC资讯: 主机资讯 注册资讯 托管资讯 vps资讯 网站建设
网站运营: 建站经验 策划盈利 搜索优化 网站推广 免费资源
网络编程: Asp.Net编程 Asp编程 Php编程 Xml编程 Access Mssql Mysql 其它
服务器技术: Web服务器 Ftp服务器 Mail服务器 Dns服务器 安全防护
软件技巧: 其它软件 Word Excel Powerpoint Ghost Vista QQ空间 QQ FlashGet 迅雷
网页制作: FrontPages Dreamweaver Javascript css photoshop fireworks Flash