利用Maven進(jìn)行開發(fā)過(guò)程管理
小明作為一個(gè)新進(jìn)開發(fā)人員,進(jìn)入了 職業(yè)生涯的第一個(gè)軟件項(xiàng)目,平日學(xué)習(xí)的開發(fā)技術(shù)就可以派上用場(chǎng)了。整個(gè)項(xiàng)目組在合作過(guò)程結(jié)果碰到了許多問(wèn)題:
1. 小明從SVN拉下分支,準(zhǔn)備開發(fā)環(huán)境導(dǎo)入,結(jié)果失敗。發(fā)現(xiàn)自己用的開發(fā)環(huán)境和公司的環(huán)境不同。
2. 小明運(yùn)行寫好的程序,結(jié)果發(fā)現(xiàn)數(shù)據(jù)庫(kù)無(wú)法連接,找了許多配置文件后,發(fā)現(xiàn)原來(lái)是自己的某個(gè)配置項(xiàng)有問(wèn)題。
3. 整體單元測(cè)試,情況無(wú)法生成報(bào)告,觀察整體項(xiàng)目情況。
4. 小明在更新別人的許多代碼后,發(fā)現(xiàn)程序起不來(lái)了,定位問(wèn)題花了很長(zhǎng)時(shí)間。
5. 小明的程序明明改了,可結(jié)果就是跟沒改前一樣。確實(shí)程序都發(fā)布了啊,后來(lái)發(fā)現(xiàn)程序依賴了一個(gè)jar包的兩個(gè)版本,而之前的版本先被加載了。
6. 檢驗(yàn)代碼風(fēng)格,規(guī)范遵循花了很長(zhǎng)時(shí)間,且有漏網(wǎng)的。
二、 基本概念
Maven是一個(gè)項(xiàng)目管理的工具。它對(duì)制件和制件間的依賴進(jìn)行了管理,并使用內(nèi)置定義生命周期來(lái)明確項(xiàng)目管理的階段,同時(shí)提供了在各階段插入插件的框架。
1 生命周期管理:
|概念:
1.生命周期(lifecycle): 對(duì)于軟件開發(fā)過(guò)程做了抽象,將其分成不同階段。在不同階段調(diào)用綁定的插件來(lái)解決特定的問(wèn)題。
2. 插件(plugin):對(duì)于過(guò)程中需要做的功能集合。比如驗(yàn)證文件布局,文件樣式;生成覆蓋率報(bào)告;打包等。
3. 目標(biāo)(goal):開發(fā)過(guò)程中需要做的功能。例如打包等。
l 目標(biāo):
開發(fā)經(jīng)理可裁剪需要的生命周期,并將生命周期內(nèi)需要做的功能如打包,生成報(bào)告,項(xiàng)目規(guī)范的檢驗(yàn)等通過(guò)插件實(shí)現(xiàn),并綁定到相應(yīng)的階段。在不同的地點(diǎn),讓其生命周期重演來(lái)確保開發(fā)過(guò)程與要求的一致性以及結(jié)果的可重演性。
其核心是維持了生命周期(Project Lifecycle),并且在周期中根據(jù)POM配置可調(diào)用相應(yīng)的可配置插件來(lái)實(shí)施個(gè)階段需要做的工作,且運(yùn)行周期目標(biāo)時(shí),會(huì)調(diào)用其先周期綁定的目標(biāo)。
2 依賴管理:
l 概念:
1. 構(gòu)件(Artifact):構(gòu)件是對(duì)一個(gè)重用單元的抽象。在java中可以是jar包,war包;在c++中可以是dll等。在maven中每一個(gè)構(gòu)件(artifact)都有唯一標(biāo)識(shí),由groupId,artifactId ,version三要素組成。
2. 依賴(dependency):構(gòu)件需要另一個(gè)構(gòu)件才能進(jìn)行操作的一種關(guān)系。一個(gè)構(gòu)件的所有依賴通過(guò)pom文件的dependency節(jié)點(diǎn)來(lái)說(shuō)明。
l 目標(biāo):
在運(yùn)行時(shí)掃描pom并得到相應(yīng)的依賴,然后對(duì)每一個(gè)依賴的制件的依賴再做提取,最后形成一顆依賴樹。
l 解決的問(wèn)題:
增加重用性:將可以重用部分的代碼做成制件,增加重用度,減少耦合,降低維護(hù)成本。
發(fā)現(xiàn)循環(huán)依賴:循環(huán)依賴會(huì)造成無(wú)法重用處在循環(huán)依賴中的任意制件,并造成局部問(wèn)題的擴(kuò)大化。
解決jar hell問(wèn)題:發(fā)現(xiàn)依賴樹中同時(shí)依賴了一個(gè)制件的不同版本。對(duì)于java而言,兩個(gè)jar包的同一全名的類只會(huì)加載一個(gè),造成運(yùn)行結(jié)果和預(yù)期結(jié)果的差異,使用其結(jié)構(gòu)可以提前發(fā)現(xiàn)并解決。
原文鏈接:http://www.cnblogs.com/jinspire/archive/2011/10/17/2214554.html
【編輯推薦】