淺談Apache Maven ToolChains的使用
簡介
因為JDK的版本現(xiàn)在以每半年一次的速度在飛速發(fā)展。不同的JDK版本就有不同的java路徑,我們在使用Maven的過程中,可能經(jīng)常會需要切換JDK的版本。
一般來說我們可以在maven-compiler-plugin中配置好executable的路徑。如下所示:
<build> <plugins> <!-- target Java 14 --> <plugin> <artifactId>maven-compiler-plugin</artifactId> <configuration> <!-- fork compilation and use the specified executable --> <fork>true</fork> <executable>/usr/bin/javac14</executable> </configuration> </plugin> </plugins> </build>
看起來還不錯,但是如果想切換executable的路徑可能就比較麻煩。更有問題的是,如果你是團(tuán)隊來發(fā),一個人在mac環(huán)境一個人在windows環(huán)境,兩邊的executable的路徑完全是不同的,這會導(dǎo)致代碼沖突,和代碼難以維護(hù)。
Toolchains的介紹
為了解決這個問題,Maven為我們推出了Toolchains。使用Toolchains,我們可以將這些可執(zhí)行文件的路徑,版本號,還有類型都定義在一個toolchains.xml文件里面。
而在pom.xml文件中只需要引用toolchains.xml中定義的別名就可以了。
針對上面的windows和linux路徑不一致的問題,我們可以保證pom.xml是完全一致的,大家只需要適配自己的toolchains.xml文件即可。
Toolchains的例子
Toolchains是和pom中其他的plugin結(jié)合起來使用的,比如最常用的maven-compiler-plugin。
下面我們舉一個例子來說明。首先定義toolchains.xml文件,這個文件最好放在${user.home}/.m2/中。
<?xml version="1.0" encoding="UTF8"?> <toolchains> <!-- JDK toolchains --> <toolchain> <type>jdk</type> <provides> <version>14</version> <vendor>oracle</vendor> </provides> <configuration> <jdkHome>/path/to/jdk/14</jdkHome> </configuration> </toolchain> <toolchain> <type>jdk</type> <provides> <version>11</version> <vendor>oracle</vendor> </provides> <configuration> <jdkHome>/path/to/jdk/11</jdkHome> </configuration> </toolchain> </toolchains>
上面的例子中,我們定義了2個JDK的toolchains。一個JDK14,一個JDK11。下面看下怎么在pom文件中使用。
<plugins> ... <plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-compiler-plugin</artifactId> <version>3.1</version> </plugin> <plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-toolchains-plugin</artifactId> <version>1.1</version> <executions> <execution> <goals> <goal>toolchain</goal> </goals> </execution> </executions> <configuration> <toolchains> <jdk> <version>14</version> <vendor>oracle</vendor> </jdk> </toolchains> </configuration> </plugin> ... </plugins>
上面的pom配置文件中,我們通過簡單的引用toolchains中的定義,即可無縫的進(jìn)行JDK版本的切換。
Toolchains支持
Toolchains需要Maven 2.0.9以上版本的支持。
Toolchains是需要和pom中的plugin一起使用的,下面的圖中列出了toolchains支持的plugin名字和最低的版本要求。
總結(jié)
本文介紹了Apache Maven中toolchain的使用,希望大家能夠在實際工作中用起來。
以上就是淺談Apache Maven ToolChains的使用的詳細(xì)內(nèi)容,更多關(guān)于Apache Maven ToolChains的使用的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
利用HttpUrlConnection 上傳 接收文件的實現(xiàn)方法
下面小編就為大家?guī)硪黄肏ttpUrlConnection 上傳 接收文件的實現(xiàn)方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-11-11java實現(xiàn)上傳網(wǎng)絡(luò)圖片到微信臨時素材
這篇文章主要為大家詳細(xì)介紹了java實現(xiàn)上傳網(wǎng)絡(luò)圖片到微信臨時素材,網(wǎng)絡(luò)圖片上傳到微信服務(wù)器,具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-07-07MyBatis?Generator?ORM層面的代碼自動生成器(推薦)
Mybatis?Generator是一個專門為?MyBatis和?ibatis框架使用者提供的代碼生成器,也可以快速的根據(jù)數(shù)據(jù)表生成對應(yīng)的pojo類、Mapper接口、Mapper文件,甚至生成QBC風(fēng)格的查詢對象,這篇文章主要介紹了MyBatis?Generator?ORM層面的代碼自動生成器,需要的朋友可以參考下2023-01-01java 方法重寫與權(quán)限修飾符以及多態(tài)和抽象類詳解概念和用法
重寫是子類對父類的允許訪問的方法的實現(xiàn)過程進(jìn)行重新編寫, 返回值和形參都不能改變。即外殼不變,核心重寫,權(quán)限修飾符用于控制被修飾變量、方法、類的可見范圍,說明了面向?qū)ο蟮姆庋b性,所以我們要適用他們盡可能的讓權(quán)限降到最低,從而安全性提高2021-10-103行代碼快速實現(xiàn)Spring Boot Oauth2服務(wù)功能
oauthserver是一個基于Spring Boot Oauth2的完整的獨立的Oauth服務(wù)器。僅僅需要創(chuàng)建相關(guān)數(shù)據(jù)表,修改數(shù)據(jù)庫的連接信息,你就可以得到一個Oauth服務(wù)器。這篇文章給大家介紹3行代碼快速實現(xiàn)Spring Boot Oauth2服務(wù)功能,需要的朋友參考下吧2018-04-04使用Jackson實現(xiàn)Map與Bean互轉(zhuǎn)方式
這篇文章主要介紹了使用Jackson實現(xiàn)Map與Bean互轉(zhuǎn)方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-08-08