精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

我們一起聊聊 Maven 依賴沖突問題

開發(fā) 前端
一般我們在解決依賴沖突的時候,都會選擇保留jar高的版本,因為大部分jar在升級的時候都會做到向下兼容,所以只要保留高的版本就不會有什么問題。

1、簡介

1.1、什么是依賴沖突

依賴沖突是指:在 Maven 項目中,當多個依賴包,引入了同一份類庫的不同版本時,可能會導致編譯錯誤或運行時異常。

1.2、依賴沖突的原因

我們在 Maven 項目的 Pom 中 一般會引用許許多多的 Dependency。例如,項目A有這樣的依賴關系:

A -> C -> X(1.0)
B -> D -> X(2.0)

X是A的 傳遞性依賴 ,但是兩條依賴路徑上有兩個版本的X,那么哪個X會被 Maven 解析使用呢? 兩個版本都被解析顯然是不對的,因為那會造成依賴重復,因此必須選擇一個。

在絕對大多數(shù)情況下,依賴沖突問題并不需要我們考慮,Maven 工具會自動根絕依賴原則選擇,這里我們先假設最終引用的 X(1.0) 版本,

1、你想如果B引用 X(2.0) 的新創(chuàng)建的類,但因為最終被解析的是 X(1.0),所以就會出現(xiàn)很典型的 NoClassDefFoundError 或 ClassNotFoundException 依賴沖突報錯。

2、如果B引用 X(2.0) 的新創(chuàng)建的方法,但因為最終被解析的是 X(1.0),所以就會拋出 NoSuchMethodError 系統(tǒng)異常。

但換種角度,如果最終解析的是 X(2.0),就沒問題了嗎?

1、如果 X(2.0) 刪掉了 X(1.0) 的一些類,但A已經(jīng)引用了,同樣也會報 NoClassDefFoundError 或者 ClassNotFoundException 錯誤。

2、如果 X(2.0) 刪掉了 X(1.0) 的一些方法,但A已經(jīng)引用了,同樣也會報 NoSuchMethodError 錯誤。

所以說具體問題還需具體分析,到底采用哪個版本還需要看實際項目。也可能我們需要升級對應的A或者B的版本才能解決問題。

2、Maven 依賴原則

2.1、層級優(yōu)先原則(路徑最近者優(yōu)先)

在同一個 Pom 內(nèi),相同 Jar 不同版本,根據(jù)依賴的路徑長短來決定引入哪個依賴。

舉例

依賴鏈路一:A -> B -> C -> X(1.0)
依賴鏈路二:F -> D -> X(2.0)

該例中 X(1.0) 的路徑長度為3,而 X(2.0) 的路徑長度為2,因此 X(2.0) 會被解析使用。依賴調(diào)解第一原則不能解決所有問題,比如這樣的依賴關系:

A -> B -> Y(1.0)
c -> D -> Y(2.0)

Y(1.0) 和 Y(2.0) 的依賴路徑長度是一樣的,都為2。Maven 定義了依賴調(diào)解的第二原則:

2.2、聲明優(yōu)先原則(第一聲明者優(yōu)先)

在依賴路徑長度相等的前提下,在同一個 Pom 中,間接依賴聲明的順序決定了誰會被解析使用,順序最前的那個依賴優(yōu)勝。該例中,如果A的依賴聲明在C之前,那么 Y (1.0) 就會被解析使用.

比如 我在 demo01 中引入了 demo02 和 demo03,demo02 和 demo03 都引入了 Lombok 的依賴

圖片圖片

demo02 和 demo03 換個順序

圖片圖片

2.3、特殊情況

  • 子Pom內(nèi)聲明的優(yōu)先于父 Pom 中的依賴。
  • 同Pom內(nèi)出現(xiàn)不同版本的相同類庫時,后聲明的會覆蓋先聲明的。也就是在同一個Pom里配置了相同資源的不同版本的直接依賴,后配置的覆蓋先配置的。比如下邊這個例子

圖片圖片

  • 調(diào)換下順序就是引用的4.12的依賴。

圖片圖片

3、如何排除依賴

我們先來解釋下什么是傳遞性依賴

3.1、什么是傳遞性依賴

比如當我們項目中,引用了A的依賴,A的依賴通常又會引入B的 Jar 包,B可能還會引入C的 Jar 包。

這樣,當你在 pom.xml 文件中添加了A的依賴,Maven 會自動的幫你把所有相關的依賴都添加進來。

就這樣一層層的,Maven 會自動的幫你把所有相關的依賴都添加進來。傳遞性依賴會給項目引入很多依賴,簡化項目依賴管理,但是也會帶來問題。

最明顯的就是容易發(fā)生依賴沖突。

3.2、如何排除依賴

這種情況下,想要解決依賴沖突,可以靠升級/降級某些依賴項的版本,從而讓不同依賴引入的同一類庫,保持一致的版本號。另外,還可以通過隱藏依賴、或者排除特定的依賴項來解決問題。

3.2.1、<exclusions>標簽

Exclusions是主動斷開依賴的資源,被排除的資源無需指定版本—指不需要

也就是說可以包含一個或者多 Exclusion 子元素,因此可以排除一個或者多個傳遞性依賴。需要注意的是,聲明 Exclusion 的時候只需要 Groupld 和 Artifactld ,而不需要要 Version 元素。

用法示例:

<dependency>
  <groupId>org.springframework</groupId>
  <artifactId>spring-web</artifactId>
  <version>5.1.8.RELEASE</version>
  <exclusions>
    <!-- 排除web包依賴的beans包 -->
    <exclusion>
      <groupId>org.springframework</groupId>
      <artifactId>spring-beans</artifactId>
    </exclusion>
  </exclusions>
</dependency>

3.2.2、<optional>標簽

該標簽即是“隱藏依賴”的開關,指對外隱藏當前所依賴的資源---指不透明:

  • true:開啟隱藏,當前依賴不會向其他工程傳遞,只保留給自己用;
  • false:默認值,表示當前依賴會保持傳遞性,其他引入當前工程的項目會間接依賴。
用法示例:
<dependency>
  <groupId>org.springframework</groupId>
  <artifactId>spring-aop</artifactId>
  <version>5.1.8.RELEASE</version>
  <optional>true</optional>
</dependency>

3.2.2.1、上邊兩種<exclusions>標簽和``<optional>標簽的區(qū)別

  • A依賴B,B依賴C , C 通過依賴傳遞會被 A 使用到,現(xiàn)在要想辦法讓 A 不去依賴 C
  • 可選依賴是在B上設置 <optional> , A 不知道有 C 的存在,代表這個依賴是否需要被發(fā)現(xiàn)。這種適用于**可以修改B的配置文件的情況下**** 先看默認情況,也就是false

圖片圖片

  • 改為 true 后

圖片圖片

  • 排除依賴是在A上設置 <exclusions> , A 知道有 C 的存在,主動將其排除掉。代表這個依賴已經(jīng)被發(fā)現(xiàn),但自己是否需要引用。這種適用于不能修改B的配置文件的情況下

圖片圖片

3.2.3、Maven 聚合工程 統(tǒng)一管理版本

聚合工程,即是指:一個項目允許創(chuàng)建多個子模塊,多個子模塊組成一個整體,可以統(tǒng)一進行項目的構建。要弄明白聚合工程,得先清楚“父子工程”的概念:

  • 父工程:不具備任何代碼、僅有pom.xml的空項目,用來定義公共依賴、插件和配置;
  • 子工程:編寫具體代碼的子項目,可以繼承父工程的配置、依賴項,還可以獨立拓展。

而Maven聚合工程,就是基于父子工程結構,來將一個完整項目,劃分出不同的層次,這種方式可以很好的管理多模塊之間的依賴關系,以及構建順序,大大提高了開發(fā)效率、維護性。

為了防止不同子工程引入不同版本的依賴,在父工程中,統(tǒng)一對依賴的版本進行控制,規(guī)定所有子工程都使用同一版本的依賴,可以使用<dependencyManagement>標簽來管理。

  • <dependencies>:定義強制性依賴,寫在該標簽里的依賴項,子工程必須強制繼承;
  • <dependencyManagement>:定義可選性依賴,該標簽里的依賴項,子工程可選擇使用。

子工程在使用<dependencyManagement>中已有的依賴項時,不需要寫<version>版本號,版本號在父工程中統(tǒng)一管理,這樣做的好處在于:以后為項目的技術棧升級版本時,不需要單獨修改每個子工程的POM,只需要修改父POM文件即可,減少了版本沖突的可能性。

4、Maven Helper 插件分析jar包沖突

如果你的項目中依賴許許多多的 Jar ,肉眼排查就沒那么方便了,這里推薦一個 Maven 管理插件

圖片圖片

在 Pom 文件中看到 Dependency Analyzer標志,說明 Maven Helper 插件就安裝成功了。

圖片圖片

點擊 Dependency Analyzer 之后就會進入到下面的頁面

圖片圖片

從圖中可以看出有哪些jar存在沖突,存在沖突的情況下最終采用了哪個依賴的版本。標紅的就是沖突版本,白色的是當前的解析版本。

如果我們想保留標紅的版本,那我們可以標白區(qū)域右擊選擇排除(Exclude)即可。

5、總結

一般我們在解決依賴沖突的時候,都會選擇保留jar高的版本,因為大部分jar在升級的時候都會做到向下兼容,所以只要保留高的版本就不會有什么問題。

但是有些包,版本變化大沒法去做向下兼容,高版本刪了低版本的某些類或者某些方法,那么這個時候就不能一股腦的去選擇高版本,但也不能選擇低版本。

就比如下面這個案例

依賴鏈路一:A -> B -> C -> X(1.0)
依賴鏈路二:F -> D -> X(2.0)

X(2.0) 沒有對 X(1.0) 做向下兼容也就是說可能存在排除哪個都不行,那怎么辦我們只能考慮升級A的版本或者降低F的版本。比如A升級到A(2.0),使它依賴的X版本變成X(2.0)這樣的話就解決依賴沖突。

但話有說回來 A升級到A(2.0) 可能會影響許許多多的地方,比如自己項目中代碼是否需要改變,或者因為 A升級到A(2.0) 導致 B和C的版本有所改變,這些影響點都需要我們?nèi)タ紤]的。所以說為什么說一個大型項目穩(wěn)定后,Pom文件的升級是件繁瑣的事情,那是因為考慮的東西是在太多了,稍有不慎就會因為依賴沖突而導致系統(tǒng)報錯。

責任編輯:武曉燕 來源: 政采云技術
相關推薦

2023-06-30 08:18:51

敏捷開發(fā)模式

2023-08-10 08:28:46

網(wǎng)絡編程通信

2023-08-04 08:20:56

DockerfileDocker工具

2022-05-24 08:21:16

數(shù)據(jù)安全API

2023-09-10 21:42:31

2023-05-09 07:51:28

Spring循環(huán)依賴

2023-10-26 08:38:43

SQL排名平分分區(qū)

2024-02-20 21:34:16

循環(huán)GolangGo

2021-08-27 07:06:10

IOJava抽象

2023-05-29 09:07:10

SQLpageSize主鍵

2024-07-26 09:47:28

2022-10-08 00:00:05

SQL機制結構

2022-02-23 08:41:58

NATIPv4IPv6

2022-09-22 08:06:29

計算機平板微信

2024-11-28 09:57:50

C#事件發(fā)布器

2021-08-12 07:49:24

mysql

2023-07-24 09:41:08

自動駕駛技術交通

2023-03-26 23:47:32

Go內(nèi)存模型

2022-10-18 07:33:57

Maven構建工具

2023-07-27 07:46:51

SAFe團隊測試
點贊
收藏

51CTO技術棧公眾號

极品av少妇一区二区| www.com污| 国产精品久久久久无码av色戒| 亚洲天堂精品一区| 美女尤物在线视频| 日韩成人精品一区| 姬川优奈aav一区二区| 欧美国产亚洲视频| 17c国产在线| 日本资源在线| 国产成人一级电影| 国产亚洲激情视频在线| 欧美 丝袜 自拍 制服 另类| 亚洲不卡免费视频| 欧美在线三级| 欧美一级日韩一级| 在线观看亚洲视频啊啊啊啊| 亚洲精品无码久久久久| 夜夜春成人影院| 欧美午夜美女看片| 欧美二区三区在线| 国产精品suv一区| 亚州国产精品| 色国产综合视频| 日韩欧美99| 乱子伦一区二区三区| 九九久久婷婷| 日本精品视频一区二区三区| 91传媒免费视频| 99精品久久久久久中文字幕| 亚洲人metart人体| 日韩视频在线一区二区| 欧美极品少妇无套实战| 亚洲精品免费在线观看视频| 蜜臀av性久久久久av蜜臀妖精| 欧美久久久一区| 先锋在线资源一区二区三区| 中文字幕有码无码人妻av蜜桃| 亚洲欧美专区| 亚洲美女淫视频| 亚洲jizzjizz日本少妇| 免费在线观看av网址| 视频精品一区| 精品二区三区线观看| 欧美xxxx吸乳| 天天操天天插天天射| 新67194成人永久网站| 国产一区二区三区视频在线观看| www.99在线| 秋霞成人影院| 国产激情一区二区三区| 国产日产欧美a一级在线| 天天看片中文字幕| 久久久伦理片| 欧美综合久久久| 中文字幕欧美日韩一区二区| 国产露出视频在线观看| 国产一区91精品张津瑜| 91精品国产一区| 91导航在线观看| 精品久久久久久久久久久aⅴ| 午夜影院久久久| 日韩高清dvd| 免费在线高清av| 国内精品伊人久久久久影院对白| 亚洲精选一区二区| 久久这里只精品| 麻豆福利在线观看| 一区二区三区中文字幕精品精品| 成人精品久久一区二区三区| 青青草手机在线观看| 综合天堂av久久久久久久| 欧美成人免费网| 法国空姐电影在线观看| 精品精品久久| 久久精品国产成人| 五级黄高潮片90分钟视频| 亚洲毛片在线免费| 91精品国产免费久久综合| 亚洲国产午夜精品| 色8久久影院午夜场| 亚洲一区二区三区四区在线免费观看| 亚洲一区免费网站| 97人妻精品一区二区三区视频| 9999国产精品| 亚洲精品一区二区三区不| 中文av一区二区三区| 91精品麻豆| 精品国产亚洲在线| 三日本三级少妇三级99| 亚洲性视频在线| 欧美吞精做爰啪啪高潮| 亚洲色成人一区二区三区小说| 欧洲成人av| 懂色av一区二区三区蜜臀| 国产精品久久久久久av下载红粉| 天天舔天天操天天干| 久久成人福利| 亚洲欧洲成视频免费观看| 无码人妻aⅴ一区二区三区玉蒲团| 污视频在线看网站| 天天爽夜夜爽夜夜爽精品视频| 手机福利在线视频| 国产在线一二三区| 久久久高清一区二区三区| 97se在线视频| 99热这里只有精品5| 久国产精品韩国三级视频| 国产精品久久久久9999| 亚洲风情第一页| 久久免费的精品国产v∧| 精品久久久久久一区二区里番| 精品国产xxx| 激情偷乱视频一区二区三区| 精品一区二区视频| 黄色一级大片在线免费看产| 国产精品久久久久久久久动漫| 成人做爽爽免费视频| 91午夜精品亚洲一区二区三区| 国产精品传媒精东影业在线| 亚洲欧洲偷拍精品| 日本一级二级视频| 日本三级亚洲精品| 国产欧美精品在线播放| 91一区二区视频| 日本欧美在线看| 国产欧美 在线欧美| 日韩精品系列| 亚洲午夜久久久久久久久电影院 | 亚洲成人五区| 在线精品播放av| 精品人妻一区二区三区蜜桃视频| 伊人久久大香线蕉| 久久久久久久久久国产| 国产精品1000| 久久精品免费| 国产免费一区视频观看免费| 免费福利在线视频| 欧美午夜女人视频在线| 亚洲精品乱码久久| 九热爱视频精品视频| 久久久久亚洲精品国产| 五月天综合在线| 久久久久久久波多野高潮日日| 国产福利精品在线| 在线免费看av的网站| 国产乱对白刺激视频不卡| 18成人免费观看网站下载| 天堂а√在线资源在线| 一区二区三区欧美| 精品一区二区中文字幕| 欧美美女在线直播| 中文字幕在线视频日韩| 久久久国产成人| 久久精品国语| 日韩av在线一区二区三区| 香蕉视频亚洲一级| 欧美一区二区免费视频| 三级黄色在线观看| 一本不卡影院| 91久久久久久久久久| 午夜免费福利在线观看| 欧美喷水一区二区| 国产又黄又粗又猛又爽的视频| 国偷自产视频一区二区久| 亚洲天堂av网| 中文字幕人妻精品一区| 国产精品久久久久久久蜜臀| 久久综合久久网| 日韩护士脚交太爽了| 亚洲高清福利视频| 免费看一级黄色| 午夜影院日韩| 日韩精品一区二区三区外面| 992tv国产精品成人影院| 精品盗摄一区二区三区| 好吊妞视频一区二区三区| 激情综合网av| 女人床在线观看| 国产成人亚洲一区二区三区| 久久精品国亚洲| 免费国产精品视频| 亚洲视频中文字幕| 亚洲一二三区av| 国产精品久久观看| 国产精品18毛片一区二区| 麻豆影视在线观看_| 日韩美女一区二区三区| 美女av免费看| 粉嫩一区二区三区在线看| 亚洲欧洲中文| 国产精品69xx| 欧美一卡2卡三卡4卡5免费| 国产在线观看你懂的| 国产无人区一区二区三区| 久久久亚洲精品无码| 中文字幕一区二区三区中文字幕 | av资源中文在线天堂| 欧美巨大另类极品videosbest| 国产成人无码精品久久二区三| 激情综合自拍| 亚洲三级一区| 精品国产午夜肉伦伦影院| 国产精品爽爽ⅴa在线观看| 女同一区二区免费aⅴ| 在线播放国产一区二区三区| 欧美 日韩 综合| 欧美精品亚洲二区| 9i精品福利一区二区三区| 亚洲一区视频在线| 欧美巨胸大乳hitomi| 99国产精品一区| 少妇高潮毛片色欲ava片| 久久高清精品| 欧美日韩亚洲一区二区三区在线观看 | 国产精品久久AV无码| 欧美日韩夜夜| 亚洲a成v人在线观看| 国模精品视频| 亚洲国产91色在线| 国产又黄又爽视频| 在线观看亚洲成人| 中文字幕视频网站| 久久美女高清视频| 又黄又色的网站| 亚洲狼人精品一区二区三区| 久久国产精品精品国产色婷婷| 成黄免费在线| 欧美日韩免费不卡视频一区二区三区| 五月激情四射婷婷| gogogo免费视频观看亚洲一| 国产 日韩 亚洲 欧美| 99精品电影| 一区二区三区四区欧美| 欧美色就是色| 91亚洲国产精品| 91在线亚洲| 国产精品日韩电影| a级在线观看| 国产婷婷色一区二区三区 | 欧美三级午夜理伦三级富婆| 欧美日韩国产高清| 国产精品一国产精品最新章节| 国产在线观看网站| 日韩电影中文字幕av| 欧美在线视频精品| 一本色道久久综合亚洲aⅴ蜜桃| 一区二区三区四区毛片| 久久精品日产第一区二区| 92看片淫黄大片一级| 999国产精品视频| 亚洲综合第一| 99久久综合狠狠综合久久aⅴ| 成人av免费在线看| 中文字幕在线免费观看视频| 精品国产区一区二区三区在线观看 | 中文在线字幕免费观| 在线视频你懂得一区| jizz国产在线| 欧美图区在线视频| 国产口爆吞精一区二区| 日韩一级片在线播放| 亚洲国产中文字幕在线| 欧美精品一区男女天堂| 国产 欧美 自拍| 91国产福利在线| 男人天堂视频在线| 欧美美女直播网站| 性欧美18一19性猛交| 欧洲一区在线观看| 亚洲一区二区影视| 日韩无一区二区| 污污视频在线观看网站| 日韩西西人体444www| 亚洲免费视频网| 日韩av网站大全| 成人18在线| 久久6免费高清热精品| eeuss影院在线播放| 久久成人免费视频| 幼a在线观看| 欧美成人免费全部观看天天性色| 91最新在线| 精品爽片免费看久久| 可以在线观看的黄色| 精品国产一区二区三区久久久狼| 美女欧美视频在线观看免费| 中文字幕av一区二区三区谷原希美| 天天干天天做天天操| 在线色欧美三级视频| 欧美日韩经典丝袜| 91地址最新发布| 欧美一级做一级爱a做片性| 国产精品日韩欧美一区二区三区| 欧美综合影院| 国产亚洲欧美一区二区三区| 欧美h版在线观看| 91精品久久久久久久久青青| 国产劲爆久久| 一区二区欧美日韩| 国产精品毛片| 日日鲁鲁鲁夜夜爽爽狠狠视频97 | 久精品免费视频| 亚洲精品一区| 97伦理在线四区| 成人影院在线| 69堂免费视频| 国产成人av福利| jizzjizz日本少妇| 色综合一个色综合| 亚洲国产精品久久久久久6q | 国产精品欧美亚洲777777 | 91亚洲精华国产精华| 任你弄精品视频免费观看| 亚洲av首页在线| 青娱乐精品在线视频| 日本一区二区在线免费观看| 亚洲男女毛片无遮挡| 在线不卡免费视频| 亚洲男人的天堂网站| 爱福利在线视频| 91系列在线播放| 久久国产成人精品| 中文字幕国内自拍| 久久97超碰色| 一区二区三区久久久久| 精品久久久久久亚洲精品| 精品久久久无码中文字幕| 最近2019年日本中文免费字幕 | 成人国产一区二区三区精品| 三上悠亚 电影| 国产99精品视频| 日韩在线视频网址| 亚洲国产欧美在线| 久草视频一区二区| 亚洲美女又黄又爽在线观看| www.8ⅹ8ⅹ羞羞漫画在线看| 91手机在线观看| 综合激情在线| 无码人妻一区二区三区精品视频| 91在线观看下载| 日韩精品一区二区三| 亚洲第一天堂无码专区| 久久不射影院| av噜噜色噜噜久久| 国产综合自拍| 日本新janpanese乱熟| 韩国一区二区视频| 99自拍视频在线| 这里只有精品视频在线观看| 免费观看的毛片| 午夜精品99久久免费| 粉嫩91精品久久久久久久99蜜桃| 成人区精品一区二区| 亚洲精品一二三区区别| 欧美网站免费观看| 91麻豆精东视频| 私库av在线播放| 在线精品视频免费观看| 大胆av不用播放器在线播放| 国产精品美女久久久免费| 久久婷婷蜜乳一本欲蜜臀| 伊人五月天婷婷| 亚洲尤物视频在线| 手机看片福利在线观看| 久久人人爽人人爽人人片亚洲| 手机在线理论片| 欧美视频小说| 美国十次了思思久久精品导航| 人人爽人人av| 国产精品嫩草影院com| 97超视频在线观看| 欧美激情中文网| 蜜桃一区二区三区| 国产女同无遮挡互慰高潮91| 亚洲午夜av在线| 精品99又大又爽又硬少妇毛片| 欧美激情一区二区三级高清视频| 欧美日韩尤物久久| 99视频国产精品免费观看| 亚洲福利免费| 亚洲日本精品视频| 91麻豆精品国产自产在线观看一区| 视频二区在线| 成人夜晚看av| 婷婷精品进入| 成人免费无码大片a毛片| 欧美系列在线观看| 99热国产在线| 成人国产精品免费视频| 在线高清一区| 最新日韩免费视频| 亚洲国产精彩中文乱码av| 成人午夜一级| 欧美亚洲一二三区| 综合色天天鬼久久鬼色| 一级黄色片视频| 91国产精品视频在线| 天天射天天综合网| 亚洲第一成人网站|