Maven 依賴管理
Maven 一個核心的特性就是依賴管理。當我們處理多模組的專案(包含成百上千個模組或者子項目),模組間的依賴關係就變得非常複雜,管理也變得很困難。針對此種情形,Maven 提供了一種高度控制的方法。
可傳遞性依賴發現
一種相當常見的情況,比如說 A 依賴於其他庫 B。如果,另外一個專案 C 想要使用 A ,那麼 C 專案也需要使用庫 B。
Maven 可以避免去搜索所有所需庫的需求。Maven 通過讀取專案檔(pom.xml),找出它們專案之間的依賴關係。
我們需要做的只是在每個專案的 pom 中定義好直接的依賴關係。其他的事情 Maven 會幫我們搞定。
通過可傳遞性的依賴,所有被包含的庫的圖形會快速的增長。當有重複庫時,可能出現的情形將會持續上升。Maven 提供一些功能來控制可傳遞的依賴的程度。
功能 |
功能描述 |
依賴調節 |
決定當多個手動創建的版本同時出現時,哪個依賴版本將會被使用。 如果兩個依賴版本在依賴樹裏的深度是一樣的時候,第一個被聲明的依賴將會被使用。 |
依賴管理 |
直接的指定手動創建的某個版本被使用。例如當一個工程 C 在自己的依賴管理模組包含工程 B,即 B 依賴於 A, 那麼 A 即可指定在 B 被引用時所使用的版本。 |
依賴範圍 |
包含在構建過程每個階段的依賴。 |
依賴排除 |
任何可傳遞的依賴都可以通過 "exclusion" 元素被排除在外。舉例說明,A 依賴 B, B 依賴 C,因此 A 可以標記 C 為 "被排除的"。 |
依賴可選 |
任何可傳遞的依賴可以被標記為可選的,通過使用 "optional" 元素。例如:A 依賴 B, B 依賴 C。因此,B 可以標記 C 為可選的, 這樣 A 就可以不再使用 C。 |
依賴範圍
傳遞依賴發現可以通過使用如下的依賴範圍來得到限制:
範圍 |
描述 |
編譯階段 |
該範圍表明相關依賴是只在專案的類路徑下有效。默認取值。 |
供應階段 |
該範圍表明相關依賴是由運行時的 JDK 或者 網路伺服器提供的。 |
運行階段 |
該範圍表明相關依賴在編譯階段不是必須的,但是在執行階段是必須的。 |
測試階段 |
該範圍表明相關依賴只在測試編譯階段和執行階段。 |
系統階段 |
該範圍表明你需要提供一個系統路徑。 |
導入階段 |
該範圍只在依賴是一個 pom 裏定義的依賴時使用。同時,當前專案的POM 檔的 部分定義的依賴關係可以取代某特定的 POM。 |
依賴管理
通常情況下,在一個共通的專案下,有一系列的專案。在這種情況下,我們可以創建一個公共依賴的 pom 檔,該 pom 包含所有的公共的依賴關係,我們稱其為其他子項目 pom 的 pom 父。 接下來的一個例子可以幫助你更好的理解這個概念。

接下來是上面依賴圖的詳情說明:
App-UI-WAR 的 pom.xml 檔代碼如下:
<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.xml 檔代碼如下:
<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.xml 檔代碼如下:
<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.xml 檔代碼如下:
<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>
現在當我們構建 App-UI-WAR 專案時, Maven 將通過遍曆依賴關係圖找到所有的依賴關係,並且構建該應用程式。
通過上面的例子,我們可以學習到以下關鍵概念:
- 公共的依賴可以使用 pom 父的概念被統一放在一起。App-Data-lib 和 App-Core-lib 專案的依賴在 Root 專案裏列舉了出來(參考 Root 的包類型,它是一個 POM).
- 沒有必要在 App-UI-W 裏聲明 Lib1, lib2, Lib3 是它的依賴。 Maven 通過使用可傳遞的依賴機制來實現該細節。