Maven核心概念
一. maven坐標
1. 什么是坐標?
在平面幾何中坐標(x,y)可以標識平面中唯一的一點
2. maven坐標主要組成:
a.) groupId:定義當前Maven項目隸屬項目
b.) artifactId:定義實際項目中的一個模塊
c.) version:定義當前項目的當前版本
d.) packaging:定義該項目的打包方式
3. maven為什么使用坐標?
maven世界擁有大量構建,我們需要找一個用來唯一標識一個構建的統一規范,擁有了統一規范,就可以把查找工作交給機器
二. 依賴管理
1. 如何進行依賴配置?
依賴范圍 scope 用來控制依賴和編譯、測試、運行的classpath的關系.
主要的三種依賴關系如下:
a.) compile: 默認編譯依賴范圍。對于編譯、測試、運行三種classpath都有效
b.) test:測試依賴范圍。只對于測試classpath有效
c.) provided:已提供依賴范圍。對于編譯,測試的classpath都有效,但對于運行無效。因為由容器已經提供,例如servlet-api
d.) runtime:運行時提供。例如:jdbc驅動
三. 倉庫管理
1. 何為maven倉庫?
用來統一存儲所有Maven共享構建的位置就是倉庫
2. maven倉庫布局
根據Maven坐標定義每個構建在倉庫中唯一存儲路徑
大致為:groupId/artifactId/version/artifactId-version.packaging
3. 倉庫的分類
a.) 本地倉庫 ~/.m2/repository/ 每個用戶只有一個本地倉庫
b.) 遠程倉庫:
中央倉庫:Maven默認的遠程倉庫 http://repo1.maven.org/maven2
私服:是一種特殊的遠程倉庫,它是架設在局域網內的倉庫
鏡像:用來替代中央倉庫,速度一般比中央倉庫快
四. 生命周期
1. 何為生命周期?
maven生命周期就是為了對所有的構建過程進行抽象和統一
包括項目清理,初始化,編譯,打包,測試,部署等幾乎所有構建步驟
2. maven三大生命周期:
maven有三套相互獨立的生命周期,請注意這里說的是“三套”,而且“相互獨立”,這三套生命周期分別是:
a.) Clean Lifecycle 在進行真正的構建之前進行一些清理工作。
b.) Site Lifecycle 生成項目報告、站點、發布站點。
c.) Default Lifecycle 構建的核心部分: 編譯、測試、打包、部署等等。
再次強調一下它們是相互獨立的,你可以僅僅調用mvn clean來清理工作目錄,僅僅調用mvn site來生成站點。
當然你也可以直接運行 mvn clean install site 運行所有這三套生命周期。
3. 生命周期詳解:
a.) Clean生命周期:
每套生命周期都由一組階段(Phase)組成,我們平時在命令行輸入的命令總會對應于一個特定的階段。
比如,運行mvn clean ,這個的clean是Clean生命周期的一個階段。有Clean生命周期,也有clean階段。Clean生命周期一共包含了三個階段:
pre-clean 執行一些需要在clean之前完成的工作
clean 移除所有上一次構建生成的文件
post-clean 執行一些需要在clean之后立刻完成的工作
mvn clean 中的clean就是上面的clean,在一個生命周期中,運行某個階段的時候,它之前的所有階段都會被運行,也就是說,mvn clean 等同于 mvn pre-clean clean ,如果我們運行 mvn post-clean ,那么 pre-clean,clean 都會被運行。這是Maven很重要的一個規則,可以大大簡化命令行的輸入。
b.) Site生命周期:
pre-site 執行一些需要在生成站點文檔之前完成的工作
site 生成項目的站點文檔
post-site 執行一些需要在生成站點文檔之后完成的工作,并且為部署做準備
site-deploy 將生成的站點文檔部署到特定的服務器上
這里經常用到的是site階段和site-deploy階段,用以生成和發布Maven站點,這可是Maven相當強大的功能,
Manager比較喜歡,文檔及統計數據自動生成,很好看。
c.) Default生命周期:
Default生命周期是Maven生命周期中最重要的一個,絕大部分工作都發生在這個生命周期中。
這里,只解釋一些比較重要和常用的階段:
validate
generate-sources
process-sources
generate-resources
process-resources 復制并處理資源文件,至目標目錄,準備打包。
compile 編譯項目的源代碼。
process-classes
generate-test-sources
process-test-sources
generate-test-resources
process-test-resources 復制并處理資源文件,至目標測試目錄。
test-compile 編譯測試源代碼。
process-test-classes
test 使用合適的單元測試框架運行測試。這些測試代碼不會被打包或部署。
prepare-package
package 接受編譯好的代碼,打包成可發布的格式,如 JAR 。
pre-integration-test
integration-test
post-integration-test
verify
install 將包安裝至本地倉庫,以讓其它項目依賴。
deploy 將最終的包復制到遠程的倉庫,以讓其它開發人員與項目共享。
運行任何一個階段的時候,它前面的所有階段都會被運行,這也就是為什么我們運行mvn install 的時候,代碼會被編譯,測試,打包。
此外,Maven的插件機制是完全依賴Maven的生命周期的,因此理解生命周期至關重要。
五. 依賴管理
傳遞性依賴: A -> B -> C ( 項目A依賴項目B, 項目B依賴項目C )
傳遞性依賴原則:
1. 路徑最近者優先: 項目B和項目C中pom.xml分別聲明依賴log4j_1.2.14和log4j_1.2.16, 那么項目A中Maven Dependencies中只會有log4j_1.2.14
2. 路徑相同, 后聲明者優先: 項目B中依次定義了log4j_1.2.14和log4j_1.2.16, 那么項目A中Maven Dependencies中只會有log4j_1.2.16
來自:http://blog.csdn.net/zdp072/article/details/36221213