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