springboot v2.0.3版本多数据源配置
本篇分享的是springboot多数据源配置,在从springboot v1.5版本升级到v2.0.3时,发现之前写的多数据源的方式不可用了,捕获错误信息如:
异常:jdbcUrl is required with driverClassName.
先来说下之前的多数据源配置如:
spring:
datasource:
url: jdbc:sqlserver://192.168.122.111;DatabaseName=flight
username: sa
password: .abcd
driver-class-name: com.microsoft.sqlserver.jdbc.SQLServerDriver
seconddatasource:
url: jdbc:sqlserver://192.168.122.111;DatabaseName=flight2
username: sa
password: .abcd
driver-class-name: com.microsoft.sqlserver.jdbc.SQLServerDriver
配置了两个数据库,在原来默认的datasource节点下面增加了seconddatasource节点的配置,然后主要的代码如:
@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的方式来对数据配置从新赋值,具体代码如:
@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版本多数据源配置的更多相关文章
- 发布日志 - kratos v2.0.4 版本发布
		V2.0.4 Release Release v2.0.4 · go-kratos/kratos (github.com) 新的功能 proto-gen-http 工具在生产代码时如果 POST/PU ... 
- springboot系列十、springboot整合redis、多redis数据源配置
		一.简介 Redis 的数据库的整合在 java 里面提供的官方工具包:jedis,所以即便你现在使用的是 SpringBoot,那么也继续使用此开发包. 二.redidTemplate操作 在 Sp ... 
- springboot+druid+mybatis plus的多数据源配置
		思路 yml中配置多个数据源信息 通过AOP切换不同数据源 配合mybatis plus使用 POM依赖 <dependency> <groupId>org.springfra ... 
- 发布日志 - kratos v2.0.5 版本发布
		V2.0.5 Release Release v2.0.5 · go-kratos/kratos (github.com) 修复问题 proto errors when swagger api imp ... 
- 2019-04-09 SpringBoot+Druid+MyBatis+Atomikos 的多数据源配置
		前面部分是网上找的,我按照网上写的把自己搭建的过程展示一次 1.引入依赖 目前项目本来使用到了Mybatis plus(在自己的Mapper接口中继承BaseMapper获得基本的CRUD,而不需要增 ... 
- MongoDB3.0.x版本用户授权配置(单机环境)
		MongoDB数据库默认情况下是没有做权限控制的,只要能够连接所开放的端口就能进行访问,而且拥有root级别的权限:对于生产环境而言是极不安全的,所以需要建立用户,进行授权控制. 单机环境下的用户授权 ... 
- Spring boot2.0 与 2.0以前版本  跨域配置的区别
		一·简介 spring boot升级到2.0后发现继承WebMvcConfigurerAdapter实现跨域过时了,那我们就紧随潮流. 二·全局配置 2.0以前 支持跨域请求代码: import or ... 
- webpack + vuejs(都是1.0的版本) 基本配置(一)
		开始之前 本文包含以下技术,文中尽量给与详细的描述,并且附上参考链接,读者可以深入学习: 1.webpack12.Vue.js13.npm4.nodejs —- 这个就不给连接了,因为上面的连接都是在 ... 
- UltraEdit-14.10.0.1024版本语法着色配置
		用了UltraEdit有段时间了,一直没做语法着色,当做普通文本编辑器使用,这也太委屈这个“神器”了. 今天就让它物尽其用吧.体验一把UltraEdit的语法高亮功能. 参考:http://www.1 ... 
随机推荐
- 跨域问题实践总结!   上(JSONP/document.domain/window.name)
			1. JSONP 首先要介绍的跨域方法必然是 JSONP. 现在你想要获取其他网站上的 JavaScript 脚本,你非常高兴的使用 XMLHttpRequest 对象来获取.但是浏览器一点儿也不配合 ... 
- 你不知道的JavaScript--Item25 创建对象(类)的8种方法总结
			1. 使用Object构造函数来创建一个对象 下面代码创建了一个person对象,并用两种方式打印出了Name的属性值. var person = new Object(); person.name= ... 
- java处理图片--图片的缩放,旋转和马赛克化
			这是我自己结合网上的一些资料封装的java图片处理类,支持图片的缩放,旋转,马赛克化.(转载请注明出处:http://blog.csdn.net/u012116457) 不多说,上代码: packag ... 
- DW自动换行
			查看→代码视图选项→自动换行 
- windows部署SpiderKeeper(爬虫监控)
			最近发现了一个spdierkeeper的库,这个库的主要用途是在于配合这scrpyd管理你的爬虫,支持一键式部署,定时采集任务,启动,暂停等一系列的操作.简单来说将scrapyd的api进行封装,最大 ... 
- python插入记录后取得主键id的方法(cursor.lastrowid和conn.insert_id())
			#!/usr/bin/python # import MySQL module import MySQLdb # get user input name = raw_input("Pleas ... 
- Python+Selenium+PIL+Tesseract真正自动识别验证码进行一键登录
			Python 2.7 IDE Pycharm 5.0.3 Selenium:Selenium的介绍及使用,强烈推荐@ Eastmount的博客 PIL : Pillow-3.3.0-cp27-cp27 ... 
- Java 学习笔记 (二) Selenium WebDriver Java 弹出框
			下面这段实例实现了以下功能: 1. profile使用用户本地电脑上的 (selenium 3有问题.因为selenium 3把profile复制到一个temp文件夹里,但并不复制回去.所以每次打开仍 ... 
- BZOJ_2600_[Ioi2011]ricehub_二分答案
			BZOJ_2600_[Ioi2011]ricehub_二分答案 Description 乡间有一条笔直而长的路称为“米道”.沿着这条米道上 R 块稻田,每块稻田的坐标均 为一个 1 到 L 之间(含 ... 
- 树莓派使用modbus与stm32通信
			树莓派+stm32开发板通信树莓派上使用java+jamod实现.jamod官网stm32使用freemodbus实现  
