Maven生命周期詳解
Maven強(qiáng)大的一個(gè)重要的原因是它有一個(gè)十分完善的生命周期模型(lifecycle),這個(gè)生命周期可以從兩方面來(lái)理解,第一,顧名思義,運(yùn)行Maven的每個(gè)步驟都由它來(lái)定義的,這種預(yù)定義的默認(rèn)行為使得我們使用Maven變得簡(jiǎn)單,相比而言,Ant的每個(gè)步驟都要你手工去定義。第二,這個(gè)模型是一種標(biāo)準(zhǔn),在不同的項(xiàng)目中,使用Maven的接口是一樣的,這樣就不用去仔細(xì)理解每個(gè)項(xiàng)目的構(gòu)建了,一般情況下,mvn clean install 這樣的命令是通用的。我想,一定是吸收了許多項(xiàng)目的經(jīng)驗(yàn),Maven才能定義出如此完善的模型。
Maven有三套相互獨(dú)立的生命周期,請(qǐng)注意這里說(shuō)的是“三套”,而且“相互獨(dú)立”,初學(xué)者容易將Maven的生命周期看成一個(gè)整體,其實(shí)不然。這三套生命周期分別是:
- Clean Lifecycle 在進(jìn)行真正的構(gòu)建之前進(jìn)行一些清理工作。
- Default Lifecycle 構(gòu)建的核心部分,編譯,測(cè)試,打包,部署等等。
- Site Lifecycle 生成項(xiàng)目報(bào)告,站點(diǎn),發(fā)布站點(diǎn)。
我再次強(qiáng)調(diào)一下它們是相互獨(dú)立的,你可以僅僅調(diào)用clean來(lái)清理工作目錄,僅僅調(diào)用site來(lái)生成站點(diǎn)。當(dāng)然你也可以直接運(yùn)行 mvn clean install site 運(yùn)行所有這三套生命周期。
知道了每套生命周期的大概用途和相互關(guān)系以后,來(lái)逐個(gè)詳細(xì)看一下每套生命周期,Clean和Site相對(duì)比較簡(jiǎn)單,先解釋一下。
每套生命周期都由一組階段(Phase)組成,我們平時(shí)在命令行輸入的命令總會(huì)對(duì)應(yīng)于一個(gè)特定的階段。比如,運(yùn)行mvn clean ,這個(gè)的clean是Clean生命周期的一個(gè)階段。有點(diǎn)繞?要知道有Clean生命周期,也有clean階段。Clean生命周期一共包含了三個(gè)階段:
- pre-clean 執(zhí)行一些需要在clean之前完成的工作
- clean 移除所有上一次構(gòu)建生成的文件
- post-clean 執(zhí)行一些需要在clean之后立刻完成的工作
mvn clean 中的clean就是上面的clean,在一個(gè)生命周期中,運(yùn)行某個(gè)階段的時(shí)候,它之前的所有階段都會(huì)被運(yùn)行,也就是說(shuō),mvn clean 等同于 mvn pre-clean clean ,如果我們運(yùn)行 mvn post-clean ,那么 pre-clean,clean 都會(huì)被運(yùn)行。這是Maven很重要的一個(gè)規(guī)則,可以大大簡(jiǎn)化命令行的輸入。
下面看一下Site生命周期的各個(gè)階段:
- pre-site 執(zhí)行一些需要在生成站點(diǎn)文檔之前完成的工作
- site 生成項(xiàng)目的站點(diǎn)文檔
- post-site 執(zhí)行一些需要在生成站點(diǎn)文檔之后完成的工作,并且為部署做準(zhǔn)備
- site-deploy 將生成的站點(diǎn)文檔部署到特定的服務(wù)器上
這里經(jīng)常用到的是site階段和site-deploy階段,用以生成和發(fā)布Maven站點(diǎn),這可是Maven相當(dāng)強(qiáng)大的功能,Manager比較喜歡,文檔及統(tǒng)計(jì)數(shù)據(jù)自動(dòng)生成,很好看。
最后,來(lái)看一下Maven的最重要的Default生命周期,絕大部分工作都發(fā)生在這個(gè)生命周期中,這里,我只解釋一些比較重要和常用的階段:
- validate
- generate-sources
- process-sources
- generate-resources
- process-resources 復(fù)制并處理資源文件,至目標(biāo)目錄,準(zhǔn)備打包。
- compile 編譯項(xiàng)目的源代碼。
- process-classes
- generate-test-sources
- process-test-sources
- generate-test-resources
- process-test-resources 復(fù)制并處理資源文件,至目標(biāo)測(cè)試目錄。
- test-compile 編譯測(cè)試源代碼。
- process-test-classes
- test 使用合適的單元測(cè)試框架運(yùn)行測(cè)試。這些測(cè)試代碼不會(huì)被打包或部署。
- prepare-package
- package 接受編譯好的代碼,打包成可發(fā)布的格式,如 JAR 。
- pre-integration-test
- integration-test
- post-integration-test
- verify
- install 將包安裝至本地倉(cāng)庫(kù),以讓其它項(xiàng)目依賴。
- deploy 將最終的包復(fù)制到遠(yuǎn)程的倉(cāng)庫(kù),以讓其它開(kāi)發(fā)人員與項(xiàng)目共享。
基本上,根據(jù)名稱我們就能猜出每個(gè)階段的用途,關(guān)于其它階段的解釋,請(qǐng)參考http://maven.apache.org/guides/introduction/introduction-to-the-lifecycle.html
記住,運(yùn)行任何一個(gè)階段的時(shí)候,它前面的所有階段都會(huì)被運(yùn)行,這也就是為什么我們運(yùn)行mvn install 的時(shí)候,代碼會(huì)被編譯,測(cè)試,打包。
此外,Maven的插件機(jī)制是完全依賴Maven的生命周期的,因此理解生命周期至關(guān)重要,在之后的文章里,我將會(huì)進(jìn)一步解釋Maven的插件機(jī)制。
posted on 2014-03-28 14:19 順其自然EVO 閱讀(409) 評(píng)論(0) 編輯 收藏 所屬分類: maven