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 依賴於 App-Core-lib 和 App-Data-lib。

  • Root 是 App-Core-lib 和 App-Data-lib 的父項目。

  • Root 在它的依賴部分定義了 Lib1、lib2 和 Lib3 作為依賴。

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 通過使用可傳遞的依賴機製來實現該細節。