Maven實戰(zhàn)(六)--- dependencies與dependencyManagement的區(qū)別

原文:Maven實戰(zhàn)(六)--- dependencies與dependencyManagement的區(qū)別

在上一個項目中遇到一些jar包沖突的問題,之后還有很多人分不清楚dependencies與dependencyManagement的區(qū)別,本篇文章將這些區(qū)別總結(jié)下來。

1、DepencyManagement應(yīng)用場景
當(dāng)我們的項目模塊很多的時候,我們使用Maven管理項目非常方便,幫助我們管理構(gòu)建、文檔、報告、依賴、scms、發(fā)布、分發(fā)的方法??梢苑奖愕木幾g代碼、進(jìn)行依賴管理、管理二進(jìn)制庫等等。

由于我們的模塊很多,所以我們又抽象了一層,抽出一個itoo-base-parent來管理子項目的公共的依賴。為了項目的正確運(yùn)行,必須讓所有的子項目使用依賴項的統(tǒng)一版本,必須確保應(yīng)用的各個項目的依賴項和版本一致,才能保證測試的和發(fā)布的是相同的結(jié)果。

在我們項目頂層的POM文件中,我們會看到dependencyManagement元素。通過它元素來管理jar包的版本,讓子項目中引用一個依賴而不用顯示的列出版本號。Maven會沿著父子層次向上走,直到找到一個擁有dependencyManagement元素的項目,然后它就會使用在這個dependencyManagement元素中指定的版本號。

來看看我們項目中的應(yīng)用:

pom繼承關(guān)系圖:


image.png

依賴關(guān)系:

Itoo-base-parent(pom.xml)

<dependencyManagement>
        
        <dependencies>
            <dependency>
                <groupId>org.eclipse.persistence</groupId>
                <artifactId>org.eclipse.persistence.jpa</artifactId>
                <version>${org.eclipse.persistence.jpa.version}</version>
                <scope>provided</scope>
            </dependency>
            
            <dependency>
                <groupId>javax</groupId>
                <artifactId>javaee-api</artifactId>
                <version>${javaee-api.version}</version>
            </dependency>
        </dependencies>
    </dependencyManagement>

Itoo-base(pom.xml)

<!--繼承父類-->
<parent>
        <artifactId>itoo-base-parent</artifactId>
        <groupId>com.tgb</groupId>
 
        <version>0.0.1-SNAPSHOT</version>
        <relativePath>../itoo-base-parent/pom.xml</relativePath>
    </parent>
        <modelVersion>4.0.0</modelVersion>
        <artifactId>itoo-base</artifactId>
        <packaging>ejb</packaging>
        
        <!--依賴關(guān)系-->
        <dependencies>
        <dependency>
            <groupId>javax</groupId>
            <artifactId>javaee-api</artifactId>
        </dependency>
        
        <dependency>
            <groupId>com.fasterxml.jackson.core</groupId>
            <artifactId>jackson-annotations</artifactId>
        </dependency>
        
        <dependency>
            <groupId>org.eclipse.persistence</groupId>
            <artifactId>org.eclipse.persistence.jpa</artifactId>
            <scope>provided</scope>
        </dependency>
    </dependencies>
</project>

這樣做的好處:統(tǒng)一管理項目的版本號,確保應(yīng)用的各個項目的依賴和版本一致,才能保證測試的和發(fā)布的是相同的成果,因此,在頂層pom中定義共同的依賴關(guān)系。同時可以避免在每個使用的子項目中都聲明一個版本號,這樣想升級或者切換到另一個版本時,只需要在父類容器里更新,不需要任何一個子項目的修改;如果某個子項目需要另外一個版本號時,只需要在dependencies中聲明一個版本號即可。子類就會使用子類聲明的版本號,不繼承于父類版本號。

2、Dependencies
相對于dependencyManagement,所有生命在dependencies里的依賴都會自動引入,并默認(rèn)被所有的子項目繼承。

3、區(qū)別
dependencies即使在子項目中不寫該依賴項,那么子項目仍然會從父項目中繼承該依賴項(全部繼承)

dependencyManagement里只是聲明依賴,并不實現(xiàn)引入,因此子項目需要顯示的聲明需要用的依賴。如果不在子項目中聲明依賴,是不會從父項目中繼承下來的;只有在子項目中寫了該依賴項,并且沒有指定具體版本,才會從父項目中繼承該項,并且version和scope都讀取自父pom;另外如果子項目中指定了版本號,那么會使用子項目中指定的jar版本。

4、Maven約定優(yōu)于配置
它提出這一概念,為項目提供合理的默認(rèn)行為,無需不必要的配置。提供了默認(rèn)的目錄

image.png

對于Maven約定優(yōu)于配置的理解,一方面對于小型項目基本滿足我們的需要基本不需要自己配置東西,使用Maven已經(jīng)配置好的,快速上手,學(xué)習(xí)成本降低;另一方面,對于不滿足我們需要的還可以自定義設(shè)置,體現(xiàn)了靈活性。配置大量減少了,隨著項目變的越復(fù)雜,這種優(yōu)勢就越明顯。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

推薦閱讀更多精彩內(nèi)容

  • 前言什么是 POMQuick Overview POM 常用元素 pom.xml 完整注釋 參考 0 前言 什么是...
    阿父閱讀 12,655評論 1 36
  • 為了項目的正確運(yùn)行,必須確保應(yīng)用的各個項目的依賴項和版本一致,才能保證測試的和發(fā)布的是相同的結(jié)果 dependen...
    杰哥長得帥閱讀 3,635評論 0 4
  • 一、maven的兩個作用 項目自動化構(gòu)建,通過命令行就可以完成整個項目構(gòu)建過程,不需要我們手動地進(jìn)行項目構(gòu)建 管理...
    lifeline張閱讀 861評論 0 1
  • 我覺得以后我可能不會要孩子了。 (雖然有沒有人愿意幫我生這還是個問題) 今天關(guān)于此想了很多。 這個想法的由來是我最...
    夾心酥閱讀 401評論 0 0
  • 2018.9.10星期一晴轉(zhuǎn)陰 今天是教師節(jié),首先祝所有的老師節(jié)日快樂! 三尺講臺育桃李、 一支粉筆寫春秋! 師者...
    李曉魯媽媽閱讀 956評論 1 2