- Maven 依賴管理

JIAN2發表於2022-08-03

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 父。 接下來的一個例子可以幫助你更好的理解這個概念。

- Maven 依賴管理

接下來是上面依賴圖的詳情說明:

  • 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 = " "   xmlns:xsi = " "   xsi:schemaLocation = "   " >       < 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 = " "   xmlns:xsi = " "   xsi:schemaLocation = "   " >       < 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 = " "   xmlns:xsi = " "   xsi:schemaLocation = "   " >       < 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 = " "   xmlns:xsi = " "   xsi:schemaLocation = "   " >       < 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 透過使用可傳遞的依賴機制來實現該細節。



來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/70006413/viewspace-2908690/,如需轉載,請註明出處,否則將追究法律責任。

相關文章