Maven 核心特點(diǎn)之一是依賴管理。一旦我們開始處理多模塊工程(包含數(shù)百個(gè)子模塊或者子工程)的時(shí)候,模塊間的依賴關(guān)系就變得非常復(fù)雜,管理也變得很困難。針對(duì)此種情形,Maven 提供了一種高度控制的方法。
這種情形經(jīng)常可見,當(dāng)一個(gè)庫(kù) A 依賴于其他庫(kù) B. 另一工程 C 想要使用庫(kù) A, 那么該工程同樣也需要使用到庫(kù) B。
Maven 可以避免去搜索所有需要的庫(kù)資源的這種需求。通過讀取工程文件(pom.xml)中的依賴項(xiàng),Maven 可以找出工程之間的依賴關(guān)系。
我們只需要在每個(gè)工程的 pom 文件里去定義直接的依賴關(guān)系。Maven 則會(huì)自動(dòng)的來(lái)接管后續(xù)的工作。
通過傳遞依賴,所有被包含的庫(kù)的圖形可能會(huì)快速的增長(zhǎng)。當(dāng)重復(fù)的庫(kù)存在時(shí),可能出現(xiàn)的情形將會(huì)持續(xù)上升。Maven 提供一些功能來(lái)控制可傳遞的依賴的程度。
功能 | 功能描述 |
---|---|
依賴調(diào)節(jié) | 決定當(dāng)多個(gè)手動(dòng)創(chuàng)建的版本同時(shí)出現(xiàn)時(shí),哪個(gè)依賴版本將會(huì)被使用。 如果兩個(gè)依賴版本在依賴樹里的深度是一樣的時(shí)候,第一個(gè)被聲明的依賴將會(huì)被使用。 |
依賴管理 | 直接的指定手動(dòng)創(chuàng)建的某個(gè)版本被使用。例如當(dāng)一個(gè)工程 C 在自己的依賴管理模塊包含工程 B,即 B 依賴于 A, 那么 A 即可指定在 B 被引用時(shí)所使用的版本。 |
依賴范圍 | 包含在構(gòu)建過程每個(gè)階段的依賴。 |
依賴排除 | 任何可傳遞的依賴都可以通過 "exclusion" 元素被排除在外。舉例說(shuō)明,A 依賴 B, B 依賴 C,因此 A 可以標(biāo)記 C 為 “被排除的”。 |
依賴可選 | 任何可傳遞的依賴可以被標(biāo)記為可選的,通過使用 "optional" 元素。例如:A 依賴 B, B 依賴 C。因此,B 可以標(biāo)記 C 為可選的, 這樣 A 就可以不再使用 C。 |
傳遞依賴發(fā)現(xiàn)可以通過使用如下的依賴范圍來(lái)得到限制:
范圍 | 描述 |
---|---|
編譯階段 | 該范圍表明相關(guān)依賴是只在工程的類路徑下有效。默認(rèn)取值。 |
供應(yīng)階段 | 該范圍表明相關(guān)依賴是由運(yùn)行時(shí)的 JDK 或者 網(wǎng)絡(luò)服務(wù)器提供的。 |
運(yùn)行階段 | 該范圍表明相關(guān)依賴在編譯階段不是必須的,但是在執(zhí)行階段是必須的。 |
測(cè)試階段 | 該范圍表明相關(guān)依賴只在測(cè)試編譯階段和執(zhí)行階段。 |
系統(tǒng)階段 | 該范圍表明你需要提供一個(gè)系統(tǒng)路徑。 |
導(dǎo)入階段 | 該范圍只在依賴是一個(gè) pom 里定義的依賴時(shí)使用。同時(shí),當(dāng)前工程的POM 文件的 部分定義的依賴關(guān)系可以取代某特定的 POM。 |
通常情況下,在一個(gè)共通的工程下,有一系列的工程。在這種情況下,我們可以創(chuàng)建一個(gè)公共依賴的 pom 文件,該 pom 包含所有的公共的依賴關(guān)系,我們稱其為其他子工程 pom 的 pom 父。 接下來(lái)的一個(gè)例子可以幫助你更好的理解這個(gè)概念。
下面是上述依賴圖表的細(xì)節(jié):
App-UI-WAR 的 POM 文件如下:
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0
http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>com.companyname.groupname</groupId>
<artifactId>App-UI-WAR</artifactId>
<version>1.0</version>
<packaging>war</packaging>
<dependencies>
<dependency>
<groupId>com.companyname.groupname</groupId>
<artifactId>App-Core-lib</artifactId>
<version>1.0</version>
</dependency>
</dependencies>
<dependencies>
<dependency>
<groupId>com.companyname.groupname</groupId>
<artifactId>App-Data-lib</artifactId>
<version>1.0</version>
</dependency>
</dependencies>
</project>
App-Core-lib 的 POM 文件如下:
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0
http://maven.apache.org/xsd/maven-4.0.0.xsd">
<parent>
<artifactId>Root</artifactId>
<groupId>com.companyname.groupname</groupId>
<version>1.0</version>
</parent>
<modelVersion>4.0.0</modelVersion>
<groupId>com.companyname.groupname</groupId>
<artifactId>App-Core-lib</artifactId>
<version>1.0</version>
<packaging>jar</packaging>
</project>
App-Data-lib 的 POM 文件如下:
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0
http://maven.apache.org/xsd/maven-4.0.0.xsd">
<parent>
<artifactId>Root</artifactId>
<groupId>com.companyname.groupname</groupId>
<version>1.0</version>
</parent>
<modelVersion>4.0.0</modelVersion>
<groupId>com.companyname.groupname</groupId>
<artifactId>App-Data-lib</artifactId>
<version>1.0</version>
<packaging>jar</packaging>
</project>
Root 的 POM 文件如下:
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0
http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>com.companyname.groupname</groupId>
<artifactId>Root</artifactId>
<version>1.0</version>
<packaging>pom</packaging>
<dependencies>
<dependency>
<groupId>com.companyname.groupname1</groupId>
<artifactId>Lib1</artifactId>
<version>1.0</version>
</dependency>
</dependencies>
<dependencies>
<dependency>
<groupId>com.companyname.groupname2</groupId>
<artifactId>Lib2</artifactId>
<version>2.1</version>
</dependency>
</dependencies>
<dependencies>
<dependency>
<groupId>com.companyname.groupname3</groupId>
<artifactId>Lib3</artifactId>
<version>1.1</version>
</dependency>
</dependencies>
</project>
現(xiàn)在,當(dāng)我們構(gòu)建 App-UI-WAR 工程時(shí), Maven 將會(huì)通過遍歷依賴圖找到所有的依賴關(guān)系,并且構(gòu)建該應(yīng)用程序。
通過上面的例子,我們可以學(xué)習(xí)到以下關(guān)鍵概念:
更多建議: