Maven強大的Java工程構建工具,作Java開發時少了跟Maven打交道,以前在知乎上看到有人提問:「學Java開發需不須要學習Maven?」,我的認爲是必須要學的,這和 工欲善其事必先利其器是一個道理,開發軟件也要先把工具學好才能 事半功倍 啊。因此最近花了一點時間,將Maven的基礎知識整理成一張腦力:
java
這篇文件主要簡單介紹一些Maven中的概念,文章大體內容以下:shell
安裝maven
配置maven
maven的命令語法
maven的構建徵集週期
其餘的一些高級特性如依賴、插件、settings部分留待以後再整理成。apache
安裝Maven
安裝Maven的步驟很是簡單、快速,安裝以前先確認 JAVA_HOME 環境變量是否指向JDK主目錄可使用 echo 命令輸出 JAVA_HOME 目錄:bash
echo $JAVA_HOME
若是輸出爲空說明 JAVA_HOME 未設置或指向不正確,可使用 export 導出 JAVA_HOME 變量:框架
export JAVA_HOME=/path/to/java_home/
要使 JAVA_HOME 變量開機生效,能夠將 JAVA_HOME=/path/to/java_home/ 放入 .profile 或 .bash_profile 視機器環境而定。jvm
設置好 JAVA_HOME 環境變量後,就能夠安裝Maven了:maven
下載 apache-maven-3.6.3-bin.zip
使用 unzip 命令解壓 apache-maven-3.6.3-bin.zip 壓縮文件
添加一個 MAVEN_HOME 環境變量,指向解壓後的 apache-maven-3.6.3-bin 目錄
將 MAVEN_HOME/bin 添加 PATH 環境變量中ide
下載 Maven工具
wget http://mirrors.tuna.tsinghua.edu.cn/apache/maven/maven-3/3.6.3/binaries/apache-maven-3.6.3-bin.zip
解壓 Maven單元測試
unzip apache-maven-3.6.3-bin.zip
設置 MAVEN_HOME 環境變量
cd apache-maven-3.6.3 pwd #查看當前目錄 export MAVEN_HOME=/Users/yjwfn/bin/apache-maven-3.6.3
設置 PATH 環境變量
export PATH=$PATH:$MAVEN_HOME/bin
以上配置只是當前 shell終端生效 ,要每次開機自動設置須要將以上命令放入 ~/.bash_profile 或 ~/.profile 中,本文使用 ~/.bash_profile (不一樣的機器名稱會不同,Linux通常叫 ~/.profile ):
vi ~/.bash_profile
將如下命令複製到文件中:
export MAVEN_HOME=/Users/yjwfn/bin/apache-maven-3.6.3 export PATH=$PATH:$MAVEN_HOME/bin
驗證安裝
使用 which mvn 命令驗證安裝是否正確,查看輸出 mvn 位置是否正確:
liuweideMacBook-Pro:bin yjwfn$ which mvn /Users/yjwfn/bin/apache-maven-3.6.3/bin/mvn
使用 mvn -v 查看安裝的 Maven 版本是否正確(由於有些系統會自帶 Maven):
liuweideMacBook-Pro:bin yjwfn$ mvn -v Apache Maven 3.6.3 (cecedd343002696d0abb 50b32b541b8a6ba2883f) Maven home: /Users/yjwfn/bin/apache-maven-3.6.3 Java version: 1.8.0_191, vendor: Oracle Corporation, runtime: /Library/Java/JavaVirtualMachines/jdk1.8.0_191.jdk/Contents/Home/jre Default locale: zh_CN, platform encoding: UTF-8 OS name: "mac os x", version: "10.14.6", arch: "x86_64", family: "mac"
運行 Maven
運行 Maven 命令的基本樣式由 options 、 goal(s) 、 phase(s) 組成:
mvn [options] [<goal(s)>] [<phase(s)>]
全部的 options 可使用 mvn -h 查看:
liuweideMacBook-Pro:bin yjwfn$ mvn -h usage: mvn [options] [<goal(s)>] [<phase(s)>] Options: -am,--also-make If project list is specified, also ....
Maven 命令的重點是 goal(s) 、 phase(s) 這兩個概念,字面意思注是目標、階段的意思。他們的使用和另一個概念 life cycles 有關,後面會詳細解釋。如今只須要明白一條 Maven 命令由多個 options 、 goal(s) 、 phase(s) 組成。
Maven配置
Maven 有三個能夠修改配置的地方:
MAVEN_OPTS 環境變量 :向全局 Maven 提供額外的選項,如JVM配置參數 -Xms256m -Xmx512m;
settings.xml :文件位於 USER_HOME/.m2 目錄中,向多個 Maven 項目提供統一的配置
.mvn 目錄:該目錄位工程目錄根目錄中,是個隱藏的文件extensions.xmlmaven.configjvm.config
MAVEN_OPTS 使用
MAVEN_OPTS 是一個環境變量,默認是空的。爲測試將 MAVEN_OPTS 設置成 -h :
export MAVEN_OPTS=-h #加個-h選項
而後執行 mvn 不帶任務參數就打印出usage:
用法: java [-options] class [args...] (執行類) 或 java [-options] -jar jarfile [args...] (執行 jar 文件)
注意:仔細一看這個 usage 實際上是Java命令輸出的 java -h :
iuweideMacBook-Pro:bin yjwfn$ java -h 用法: java [-options] class [args...] (執行類) 或 java [-options] -jar jarfile [args...] (執行 jar 文件)
測試 java -h 與將 MAVEN_OPTS 設置成 -h 而後執行 mvn 打印出來的效果一致,因此 MAVEN_OPTS 你們應該知道怎麼用了吧! 要往JVM傳遞參數能夠經過 MAVEN_OPTS 變量設置 。
settings.xml 文件
settings.xml 能夠放在兩個地址:
$MAVEN_HOME/conf/settings.xml USER_HOME/.m2
$MAVEN_HOME 就是安裝步驟中設置的環境變量, settings.xml 的加載能夠打開 --debug 選項查看:
mvn --debug # 部分控制檯輸出 [DEBUG] Reading global settings from /Users/yjwfn/bin/apache-maven-3.6.3/conf/settings.xml [DEBUG] Reading user settings from /Users/yjwfn/.m2/settings.xml
如控制檯輸出同樣,會在 $MAVEN_HOME 和 USER_HOME/.m2 中加載兩個 settings.xml 文件。 settings.xml 的配置項很是多,就不詳細說明了能夠查看官方文檔。
mvn 目錄
mvn 目錄位於工程根目錄中,是工程級的配置通常包含三個配置文件:
extensions.xml
maven.config
jvm.config
Maven Extensions
extensions.xml 是爲了使開發者更方便的使用 Extensions 功能創建的配置文件, Extensions 是一種添加庫到 Core Classloader 的方式 , Maven 主要有四類 System Classloader -> Core Classloader -> Plugin Classloaders -> Custom Classloaders 因爲 CloassLoader 都是雙親委派模式,因此添加到 Core Classloader 中的庫能夠在 Plugin Classloaders 和 Custom Classloaders 中使用:
extensions.xml的配置演示:
extensions.xml 這個配置文件就是聲明哪些庫須要添加到 Core Classloader 中,以下聲明將 guava 添加到 Core Classloader 中:
<extensions xmlns="http://maven.apache.org/EXTENSIONS/1.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/EXTENSIONS/1.0.0 http://maven.apache.org/xsd/core-extensions-1.0.0.xsd"> <extension> <groupId>com.google.guava</groupId> <artifactId>guava</artifactId> <version>23.0</version> </extension> </extensions>
maven.config
maven.config 主要用於添加通用選項,在執行 mvn 命令時會將 maven.config 中配置的命令options添加到命令中。
新建個maven.config文件,內容以下:
-v
直接執行 mvn 不帶任何選項,因爲在 maven.config 中有 -v 選項,因此打出的內容就是 mvn -v :
liuweideMacBook-Pro:.mvn yjwfn$ mvn Apache Maven 3.6.3 (cecedd343002696d0abb50b32b541b8a6ba2883f) Maven home: /Users/yjwfn/bin/apache-maven-3.6.3 Java version: 1.8.0_191, vendor: Oracle Corporation, runtime: /Library/Java/JavaVirtualMachines/jdk1.8.0_191.jdk/Contents/Home/jre Default locale: zh_CN, platform encoding: UTF-8 OS name: "mac os x", version: "10.14.6", arch: "x86_64", family: "mac" liuweideMacBook-Pro:.mvn yjwfn$
jvm.config
jvm.config 是配置JVM參數的文件,很容易理解就很少說了。
Maven 構建生命週期
構建生命週期 就Maven較核心的概念, Maven有三個內置的構建生命週期分別爲: clean 、 default 、 site 。
構建階段(Build Phase)
在Maven中 一個生命週期由一系列 Build Phase 組成 ,而每一個生命週期都會有不少 Build Phase 如 default 生命週期由如下 Build Phase 組成:
validate -確認項目正確而且全部必要的信息都可用
compile -編譯項目的源代碼
test-使用合適的單元測試框架測試編譯後的源代碼。這些測試不該要求將代碼打包或部署
package -獲取編譯後的代碼,並將其打包爲可分發的格式,例如JAR。
verify -對集成測試的結果進行任何檢查,以確保符合質量標準
install -將軟件包安裝到本地存儲庫中,以做爲本地其餘項目中的依賴項
deploy -在構建環境中完成後,將最終軟件包複製到遠程存儲庫中,以便與其餘開發人員和項目共享。
這些生命週期階段(加上此處未顯示的其餘生命週期階段)將順序執行以完成 default 生命週期。給定上面的生命週期階段,這意味着當使用 default 生命週期時,Maven將首先驗證項目,而後嘗試編譯源代碼,針對測試運行源代碼,打包二進制文件(例如jar),針對該源運行集成測試軟件包,驗證集成測試,將通過驗證的軟件包安裝到本地存儲庫,而後將已安裝的軟件包部署到遠程存儲庫。
插件目標(Plugin Goals)
Build Phase 只是定義一些軟件構建的流程,它不會直接去構建工程,這些構建流程的實施都是由 插件 來作的,構建生命週期能夠這樣理解 一個生命週期由多個構建階段組成,每一個構建階段都會被多個插件目標綁定 ,用一張圖表示他們之間的關係:
圖中的 jar:jar 、 install:install 是 plugin:goal 的意思,冒號的前面部分是插件名稱,後面是目標名稱。由上圖可知當執行 mvn install 的命令時,會執行 default 生命週期中的 install 階段(同時在install以前的階段也會執行),因爲 install:install 目標綁定到了 install phase ,因此 install:install 目標也會執行,這樣就經過 install 插件來完成打包功能。
總結Maven是很是流行的構建工具,下一代構建工具 Gradle 也有一些點是借鑑了Maven。文中所提到的點只是Maven工具的一部分知識,Maven還有不少強大的功能如:依賴管理、插件管理、多工程等功能,後續再整理這些高級功能與你們分享。