您好,登錄后才能下訂單哦!
這篇文章主要介紹了springbootv2.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: 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節點的配置,然后主要的代碼如:
@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在升級迭代的過程中一些細微的變動,這或許會給我們在學習和升級過程中造成麻煩,所以官網每次升級的內容說明還是有必要看下的。
感謝你能夠認真閱讀完這篇文章,希望小編分享的“springbootv2.0.3版本多數據源配置的示例分析”這篇文章對大家有幫助,同時也希望大家多多支持億速云,關注億速云行業資訊頻道,更多相關知識等著你來學習!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。