Spring Boot項(xiàng)目添加外部Jar包以及配置多數(shù)據(jù)源的完整步驟
前言
最近項(xiàng)目需要和Oracle數(shù)據(jù)庫進(jìn)行交互,然后我從Maven中央倉庫下載數(shù)據(jù)庫驅(qū)動jar包,但怎么都下不下來,我到Oracle官網(wǎng)上一看,我去,居然不讓用Maven直接下(大學(xué)時(shí)候用過Oracle,很久遠(yuǎn)的事情了0rz),沒辦法我還是直接下載jar包放到我的項(xiàng)目里面吧。SpringBoot項(xiàng)目引入外部jar包是非常方便的,包含打引入外部jar等操作。
我的做法如下:
首先在src同級目錄建一個(gè)lib文件夾,將第三方j(luò)ar包放到這個(gè)文件內(nèi),比如我將ojdbc6.jar 這個(gè)jar包放到這個(gè)地方。
接著我們需要在pom.xml文件里配置jar的maven坐標(biāo),不過這個(gè)坐標(biāo)比較特殊,我們需要直接定位到我們上一步添加的文件,而不是從Maven倉庫里面去下載,以ojdbc6.jar為例,配置依賴如下:
<dependency> <groupId>com.oracle</groupId> <artifactId>ojdbc6</artifactId> <version>12.1.0.2.0</version> <scope>system</scope> <systemPath>${project.basedir}/lib/ojdbc6.jar</systemPath> </dependency>
這里比較特殊的是systemPath,常見的Maven坐標(biāo)是沒有這個(gè)的,這里面直接指定該jar的相對路徑(相對項(xiàng)目的根目錄),這樣Maven在編譯的時(shí)候就不會從中央倉庫里面去下載該jar包了。但只配置這個(gè)還不行,還需要配置SpringBoot編譯時(shí)插件屬性includeSystemScope,具體如下:
<plugin> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-maven-plugin</artifactId> <configuration> <includeSystemScope>true</includeSystemScope> </configuration> </plugin>
上面配置完畢,我們就可以直接執(zhí)行mvn clean install進(jìn)行打包,然后我們查看打好的jar包里面包含的jar包,會發(fā)現(xiàn)ojdbc6.jar這個(gè)包已經(jīng)正確被包含進(jìn)去了。
由于對接的項(xiàng)目比較老,要與其數(shù)據(jù)庫進(jìn)行交互,而且數(shù)據(jù)庫類型不一致,所以我們的項(xiàng)目需要支持多數(shù)據(jù)源(接口平臺),這個(gè)還是非常好配置的,SpringBoot給我們提供了多數(shù)據(jù)源配置的方案,并且每個(gè)數(shù)據(jù)源對應(yīng)一個(gè)JdbcTemplate,這樣就方便很多,具體配置如下:
application.properties文件內(nèi)配置多數(shù)據(jù)源信息
首先在application.properties或者yml文件內(nèi)配置多數(shù)據(jù)源信息,具體配置如下:
# ds1數(shù)據(jù)源配置 spring.datasource.ds1.type=com.alibaba.druid.pool.DruidDataSource spring.datasource.ds1.driver-class-name=com.mysql.jdbc.Driver spring.datasource.ds1.url=jdbc:mysql://localhost:3306/zz?useUnicode=true&characterEncoding=utf8 spring.datasource.ds1.username=zz spring.datasource.ds1.password=zz # ds2數(shù)據(jù)源配置 spring.datasource.ds2.driver-class-name=oracle.jdbc.driver.OracleDriver spring.datasource.ds2.url=jdbc:oracle:thin:@localhost:1521:orcl spring.datasource.ds2.username=system spring.datasource.ds2.password=050508
指定數(shù)據(jù)源與配置信息
上面我們配置好了數(shù)據(jù)源,但是已經(jīng)不是SpringBoot默認(rèn)的數(shù)據(jù)源配置信息了,所以我們還要指定不同的數(shù)據(jù)源實(shí)例對應(yīng)哪個(gè)配置信息,配置如下:
/** * 多數(shù)據(jù)源配置 */ public class DataSourceConfig { /** * ds1數(shù)據(jù)源配置 * * @return 配置信息 */ (name = "ds1DataSourceProperties") (prefix = "spring.datasource.ds1") public DataSourceProperties ds1DataSourceProperties() { return new DataSourceProperties(); } /** * ds1數(shù)據(jù)源 * * @param dataSourceProperties 配置信息 * @return 數(shù)據(jù)源實(shí)例 */ (name = "ds1DataSource") public DataSource ds1DataSource(@Qualifier("ds1DataSourceProperties") DataSourceProperties dataSourceProperties) { return dataSourceProperties.initializeDataSourceBuilder().build(); } /** * ds2數(shù)據(jù)源配置 * * @return 配置信息 */ (name = "ds2DataSourceProperties") (prefix = "spring.datasource.ds2") public DataSourceProperties ds2DataSourceProperties() { return new DataSourceProperties(); } /** * ds2數(shù)據(jù)源 * * @param dataSourceProperties 配置信息 * @return 數(shù)據(jù)源實(shí)例 */ (name = "ds2DataSource") public DataSource ds2DataSource(@Qualifier("ds2DataSourceProperties") DataSourceProperties dataSourceProperties) { return dataSourceProperties.initializeDataSourceBuilder().build(); } }
配置JdbcTemplate與數(shù)據(jù)源關(guān)系
配置完數(shù)據(jù)源信息,我們想直接用不同的JdbcTemplate來操作不同的數(shù)據(jù)庫,所以我們還要?jiǎng)?chuàng)建幾個(gè)JdbcTemplate實(shí)例,并且這些實(shí)例與不同的數(shù)據(jù)源進(jìn)行綁定,配置信息如下:
/** * JdbcTemplate 多數(shù)據(jù)源配置 * * @author 明山 * @see DataSourceConfig */ public class JdbcTemplateDataSourceConfig { /** * ds1 JdbcTemplate 配置 * * @param dataSource 數(shù)據(jù)源 * @return JdbcTemplate */ (name = "ds1JdbcTemplate") public JdbcTemplate jdbcTemplate(@Qualifier("ds1DataSource") DataSource dataSource) { return new JdbcTemplate(dataSource); } /** *ds2 JdbcTemplate 配置 * * @param dataSource 數(shù)據(jù)源 * @return JdbcTemplate */ (name = "ds2JdbcTemplate") public JdbcTemplate hdwmsJdbcTemplate(@Qualifier("ds2DataSource") DataSource dataSource) { return new JdbcTemplate(dataSource); } }
使用JdbcTemplate
配置完后,我們可以直接在具體的類中使用了,使用方式如下:
("ds1JdbcTemplate") private JdbcTemplate ds1JdbcTemplate; ("ds2JdbcTemplate") private JdbcTemplate ds2JdbcTemplate;
總結(jié)
到此這篇關(guān)于Spring Boot項(xiàng)目添加外部Jar包以及配置多數(shù)據(jù)源的文章就介紹到這了,更多相關(guān)Spring Boot項(xiàng)目添加外部Jar包及配置多數(shù)據(jù)源內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
深入剖析java中String、StringBuffer、StringBuilder的區(qū)別
下面小編就為大家?guī)硪黄钊肫饰鰆ava中String、StringBuffer、StringBuilder的區(qū)別。小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2016-05-05Java遞歸算法經(jīng)典實(shí)例(經(jīng)典兔子問題)
本文主要對經(jīng)典的兔子案例分析,來進(jìn)一步更好的理解和學(xué)習(xí)java遞歸算法,具有很好的參考價(jià)值,需要的朋友一起來看下吧2016-12-12springboot?整合?dubbo?的實(shí)現(xiàn)組聚合詳情
這篇文章主要介紹了springboot整合dubbo的實(shí)現(xiàn)組聚合詳情,文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下2022-07-07SpringCloud Gateway的熔斷限流配置實(shí)現(xiàn)方法
Spring Cloud Gateway支持通過配置熔斷和限流機(jī)制來保證服務(wù)的穩(wěn)定性和可用性,可通過Hystrix和Resilience4j兩種方式實(shí)現(xiàn)。Hystrix通過注解和配置文件實(shí)現(xiàn)熔斷限流,Resilience4j通過編程式配置實(shí)現(xiàn)2023-04-04java枚舉類的構(gòu)造函數(shù)實(shí)例詳解
這篇文章主要介紹了java枚舉類的構(gòu)造函數(shù)實(shí)例詳解的相關(guān)資料,需要的朋友可以參考下2017-05-05