Maven dependencyManagement元素標(biāo)簽的具體使用
我們知道,子模塊可以通過繼承獲得父模塊中聲明的全部依賴,這樣雖然避免了在各個(gè)子模塊 POM 中重復(fù)進(jìn)行依賴聲明,但也極有可能造成子模塊中引入一些不必要的依賴。為此 Maven 引入了 dependencyManagement 來對(duì)依賴進(jìn)行管理。
依賴管理
Maven 可以通過 dependencyManagement 元素對(duì)依賴進(jìn)行管理,它具有以下 2 大特性:
- 在該元素下聲明的依賴不會(huì)實(shí)際引入到模塊中,只有在 dependencies 元素下同樣聲明了該依賴,才會(huì)引入到模塊中。
- 該元素能夠約束 dependencies 下依賴的使用,即 dependencies 聲明的依賴若未指定版本,則使用 dependencyManagement 中指定的版本,否則將覆蓋 dependencyManagement 中的版本。
例如,修改 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 https://maven.apache.org/xsd/maven-4.0.0.xsd"> <modelVersion>4.0.0</modelVersion> <!--由于不是繼承,所以必須重新添加 groupId 和 version--> <groupId>org.example</groupId> <artifactId>App-Data-lib</artifactId> <version>1.0</version> <!--dependencyManagement 標(biāo)簽用于控制子模塊的依賴版本等信息 --> <!-- 該標(biāo)簽只用來控制版本,不能將依賴引入 --> <dependencyManagement> <dependencies> <dependency> <groupId>log4j</groupId> <artifactId>log4j</artifactId> <!--引用的properties標(biāo)簽中定義的屬性 --> <version>1.2.17</version> </dependency> <dependency> <groupId>junit</groupId> <artifactId>junit</artifactId> <!--引用的properties標(biāo)簽中定義的屬性 --> <version>4.9</version> <!-- <scope>test</scope> --> </dependency> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <!--引用的properties標(biāo)簽中定義的屬性 --> <version>5.1.18</version> <scope>runtime</scope> </dependency> <dependency> <groupId>c3p0</groupId> <artifactId>c3p0</artifactId> <!--引用的properties標(biāo)簽中定義的屬性 --> <version>0.9.1</version> </dependency> </dependencies> </dependencyManagement> <!--聲明依賴--> <dependencies> <dependency> <groupId>junit</groupId> <artifactId>junit</artifactId> </dependency> </dependencies> </project>
在以上配置中,由于 dependencyManagement 元素中已經(jīng)定義完整的依賴聲明,所以在 dependencies 元素中聲明的依賴只配置了 groupId 和 artifactId,省略了 version 和 scope。
在實(shí)際的開發(fā)過程中,dependencyManagement 很少會(huì)單獨(dú)使用,通常它需要與 Maven 繼承或依賴范圍 import 配合使用才能展現(xiàn)它的優(yōu)勢(shì)。
繼承依賴管理
由于 dependencyManagement 元素是可以被繼承的,因此我們可以在父模塊 POM 中使用 dependencyManagement 元素聲明所有子模塊的依賴,然后在各個(gè)子模塊 POM 使用 dependencies 元素聲明實(shí)際用到的依賴即可。這樣既可以讓子模塊能夠繼承父模塊的依賴配置,還能避免將不必要的依賴引入到子模塊中。
1. 修改父模塊 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 https://maven.apache.org/xsd/maven-4.0.0.xsd"> <modelVersion>4.0.0</modelVersion> <groupId>org.example</groupId> <artifactId>Root</artifactId> <version>1.0</version> <!--定義的父類pom.xml 打包類型使pom --> <packaging>pom</packaging> <properties> <!-- 定義一些 maven 變量 --> <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding> <log4j.version>1.2.17</log4j.version> <junit.version>4.9</junit.version> <system.version>1.0</system.version> <mysql.connector.version>5.1.18</mysql.connector.version> <c3p0.version>0.9.1</c3p0.version> </properties> <!--dependencyManagement 標(biāo)簽用于控制子模塊的依賴版本等信息 --> <!-- 該標(biāo)簽只用來控制版本,不能將依賴引入 --> <dependencyManagement> <dependencies> <dependency> <groupId>log4j</groupId> <artifactId>log4j</artifactId> <!--引用的properties標(biāo)簽中定義的變量 --> <version>${log4j.version}</version> </dependency> <dependency> <groupId>junit</groupId> <artifactId>junit</artifactId> <!--引用的properties標(biāo)簽中定義的變量 --> <version>${junit.version}</version> <!-- <scope>test</scope> --> </dependency> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <!--引用的properties標(biāo)簽中定義的變量 --> <version>${mysql.connector.version}</version> <scope>runtime</scope> </dependency> <dependency> <groupId>c3p0</groupId> <artifactId>c3p0</artifactId> <!--引用的properties標(biāo)簽中定義的變量 --> <version>${c3p0.version}</version> </dependency> </dependencies> </dependencyManagement> </project>
注:以上配置中,將所有依賴的版本信息以 Maven 變量(properties)的形式提取出來,這樣不僅消除了一些重復(fù),也使得各個(gè)依賴的版本信息更加明顯,便于管理。
在父模塊 Root 中使用 dependencyManagement 元素聲明的依賴,既不會(huì)給 Root 模塊引入依賴,也不會(huì)給其子模塊引入依賴,但這段配置是可以被繼承的。
2. 修改子模塊 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 https://maven.apache.org/xsd/maven-4.0.0.xsd"> <modelVersion>4.0.0</modelVersion> <artifactId>App-Core-lib</artifactId> <parent> <groupId>org.example</groupId> <artifactId>Root</artifactId> <version>1.0</version> <relativePath>../Root</relativePath> </parent> <dependencies> <dependency> <groupId>log4j</groupId> <artifactId>log4j</artifactId> </dependency> <dependency> <groupId>junit</groupId> <artifactId>junit</artifactId> </dependency> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> </dependency> <dependency> <groupId>c3p0</groupId> <artifactId>c3p0</artifactId> </dependency> </dependencies> <distributionManagement> <repository> <id>bianchengbang_Release_hosted</id> <url>http://localhost:8082/nexus/content/repositories/bianchengbang_Release_hosted/</url> </repository> <snapshotRepository> <id>Snapshot</id> <url>http://localhost:8082/nexus/content/repositories/bianchengbang_Snapshot_hosted/</url> </snapshotRepository> </distributionManagement> </project>
在子模塊 App-Core-lib 和 App-Data-lib 的 POM 中,所有在 dependencies 元素中聲明的依賴都只配置了 groupId 和 artifactId,省去了 version 和 scope。之所以能夠省略這些信息,是因?yàn)樗鼈兝^承了父模塊 Root 中 dependencyManagement 的配置,其完整的依賴聲明已經(jīng)包含在父模塊的 POM 中,子模塊只需要配置 groupId 和 artifactId 就能獲得相應(yīng)的依賴信息,從而引入正確的依賴。
使用這種依賴管理機(jī)制似乎并不能減少太多 POM 配置,但我們?nèi)匀煌扑]使用這種方式,其原因主要有 2 個(gè):
-在父模塊中使用 dependencyManagement 聲明依賴能夠統(tǒng)一項(xiàng)目?jī)?nèi)依賴的版本,子模塊無須聲明版本,也就不會(huì)出現(xiàn)多個(gè)子模塊使用同一依賴項(xiàng)版本不一致的情況,降低依賴沖突的幾率。
- dependencyManagement 聲明的依賴不會(huì)被實(shí)際引入,子模塊需要什么依賴就自己引入,增加了靈活性,避免引入一些不必要的依賴。
導(dǎo)入依賴管理
因?yàn)?import 依賴范圍只能與 dependencyManagement 元素配合使用才會(huì)有效,其功能是將目標(biāo) pom.xml 中的 dependencyManagement 配置導(dǎo)入合并到當(dāng)前 pom.xml 的 dependencyManagement 中。
例如,App-Data-lib 模塊想要使用 Root 模塊中的 dependencyManagement 配置,除了通過繼承或者直接復(fù)制這兩種方式之外,還可以使用 import 依賴范圍將其導(dǎo)入,具體配置如下。
<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 https://maven.apache.org/xsd/maven-4.0.0.xsd"> <modelVersion>4.0.0</modelVersion> <!--由于不是繼承,所以必須重新添加 groupId 和 version--> <groupId>org.example</groupId> <artifactId>App-Data-lib</artifactId> <version>1.0</version> <!--定義依賴管理--> <dependencyManagement> <dependencies> <!--導(dǎo)入依賴管理配置--> <dependency> <groupId>org.example</groupId> <artifactId>Root</artifactId> <version>1.0</version> <!--依賴范圍為 import--> <scope>import</scope> <!--類型一般為pom--> <type>pom</type> </dependency> </dependencies> </dependencyManagement> <!--聲明依賴--> <dependencies> <dependency> <groupId>junit</groupId> <artifactId>junit</artifactId> </dependency> </dependencies> </project>
以上配置中,由于 import 依賴范圍的特殊性,一般都是指向打包類型為 pom 的模塊,所以 type 元素的值一般為 pom。
若存在多個(gè)模塊,它們使用的依賴版本都是一致的,則就可以定義一個(gè)使用 dependencyManagement 專門管理依賴的 POM,然后在各個(gè)模塊中導(dǎo)入這些依賴管理配置。
到此這篇關(guān)于Maven dependencyManagement元素標(biāo)簽的具體使用的文章就介紹到這了,更多相關(guān)Maven dependencyManagement內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Netty啟動(dòng)流程注冊(cè)多路復(fù)用源碼解析
這篇文章主要介紹了Netty啟動(dòng)流程注冊(cè)多路復(fù)用源碼分析,繼續(xù)分析channel是如何注冊(cè)到selector中的,有需要的朋友可以借鑒參考下,希望能夠有所幫助2022-03-03Maven忽略單元測(cè)試及打包到Nexus的實(shí)現(xiàn)
我們的工程在打包發(fā)布時(shí)候,通常都需要忽略單元測(cè)試,以免因環(huán)境原因,無法通過單元測(cè)試而影響發(fā)布,本文主要介紹了Maven忽略單元測(cè)試及打包到Nexus的實(shí)現(xiàn),感興趣的可以了解一下2024-04-04關(guān)于SpringBoot的自動(dòng)裝配原理詳解
這篇文章主要介紹了關(guān)于SpringBoot的自動(dòng)裝配原理詳解,Spring?Boot自動(dòng)裝配原理是指Spring?Boot在啟動(dòng)時(shí)自動(dòng)掃描項(xiàng)目中的依賴關(guān)系,根據(jù)依賴關(guān)系自動(dòng)配置相應(yīng)的Bean,從而簡(jiǎn)化了Spring應(yīng)用的配置過程,需要的朋友可以參考下2023-07-07feign調(diào)用中文參數(shù)被encode編譯的問題
這篇文章主要介紹了feign調(diào)用中文參數(shù)被encode編譯的問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-03-03