日韩成人免费在线_国产成人一二_精品国产免费人成电影在线观..._日本一区二区三区久久久久久久久不

當前位置:首頁 > 科技  > 軟件

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

來源: 責編: 時間:2024-02-29 14:40:54 245觀看
導讀1、簡介1.1、什么是依賴沖突依賴沖突是指:在 Maven 項目中,當多個依賴包,引入了同一份類庫的不同版本時,可能會導致編譯錯誤或運行時異常。1.2、依賴沖突的原因我們在 Maven 項目的 Pom 中 一般會引用許許多多的 Dependen

1、簡介

1.1、什么是依賴沖突

依賴沖突是指:在 Maven 項目中,當多個依賴包,引入了同一份類庫的不同版本時,可能會導致編譯錯誤或運行時異常。BnH28資訊網——每日最新資訊28at.com

1.2、依賴沖突的原因

我們在 Maven 項目的 Pom 中 一般會引用許許多多的 Dependency。例如,項目A有這樣的依賴關系:BnH28資訊網——每日最新資訊28at.com

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

X是A的 傳遞性依賴 ,但是兩條依賴路徑上有兩個版本的X,那么哪個X會被 Maven 解析使用呢? 兩個版本都被解析顯然是不對的,因為那會造成依賴重復,因此必須選擇一個。BnH28資訊網——每日最新資訊28at.com

在絕對大多數情況下,依賴沖突問題并不需要我們考慮,Maven 工具會自動根絕依賴原則選擇,這里我們先假設最終引用的 X(1.0) 版本,BnH28資訊網——每日最新資訊28at.com

1、你想如果B引用 X(2.0) 的新創建的類,但因為最終被解析的是 X(1.0),所以就會出現很典型的 NoClassDefFoundError 或 ClassNotFoundException 依賴沖突報錯。BnH28資訊網——每日最新資訊28at.com

2、如果B引用 X(2.0) 的新創建的方法,但因為最終被解析的是 X(1.0),所以就會拋出 NoSuchMethodError 系統異常。BnH28資訊網——每日最新資訊28at.com

但換種角度,如果最終解析的是 X(2.0),就沒問題了嗎?BnH28資訊網——每日最新資訊28at.com

1、如果 X(2.0) 刪掉了 X(1.0) 的一些類,但A已經引用了,同樣也會報 NoClassDefFoundError 或者 ClassNotFoundException 錯誤。BnH28資訊網——每日最新資訊28at.com

2、如果 X(2.0) 刪掉了 X(1.0) 的一些方法,但A已經引用了,同樣也會報 NoSuchMethodError 錯誤。BnH28資訊網——每日最新資訊28at.com

所以說具體問題還需具體分析,到底采用哪個版本還需要看實際項目。也可能我們需要升級對應的A或者B的版本才能解決問題。BnH28資訊網——每日最新資訊28at.com

2、Maven 依賴原則

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

在同一個 Pom 內,相同 Jar 不同版本,根據依賴的路徑長短來決定引入哪個依賴。BnH28資訊網——每日最新資訊28at.com

舉例BnH28資訊網——每日最新資訊28at.com

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

該例中 X(1.0) 的路徑長度為3,而 X(2.0) 的路徑長度為2,因此 X(2.0) 會被解析使用。依賴調解第一原則不能解決所有問題,比如這樣的依賴關系:BnH28資訊網——每日最新資訊28at.com

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

Y(1.0) 和 Y(2.0) 的依賴路徑長度是一樣的,都為2。Maven 定義了依賴調解的第二原則:BnH28資訊網——每日最新資訊28at.com

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

在依賴路徑長度相等的前提下,在同一個 Pom 中,間接依賴聲明的順序決定了誰會被解析使用,順序最前的那個依賴優勝。該例中,如果A的依賴聲明在C之前,那么 Y (1.0) 就會被解析使用.BnH28資訊網——每日最新資訊28at.com

比如 我在 demo01 中引入了 demo02 和 demo03,demo02 和 demo03 都引入了 Lombok 的依賴BnH28資訊網——每日最新資訊28at.com

圖片圖片BnH28資訊網——每日最新資訊28at.com

demo02 和 demo03 換個順序BnH28資訊網——每日最新資訊28at.com

圖片圖片BnH28資訊網——每日最新資訊28at.com

2.3、特殊情況

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

圖片圖片BnH28資訊網——每日最新資訊28at.com

  • 調換下順序就是引用的4.12的依賴。

圖片圖片BnH28資訊網——每日最新資訊28at.com

3、如何排除依賴

我們先來解釋下什么是傳遞性依賴BnH28資訊網——每日最新資訊28at.com

3.1、什么是傳遞性依賴

比如當我們項目中,引用了A的依賴,A的依賴通常又會引入B的 Jar 包,B可能還會引入C的 Jar 包。BnH28資訊網——每日最新資訊28at.com

這樣,當你在 pom.xml 文件中添加了A的依賴,Maven 會自動的幫你把所有相關的依賴都添加進來。BnH28資訊網——每日最新資訊28at.com

就這樣一層層的,Maven 會自動的幫你把所有相關的依賴都添加進來。傳遞性依賴會給項目引入很多依賴,簡化項目依賴管理,但是也會帶來問題。BnH28資訊網——每日最新資訊28at.com

最明顯的就是容易發生依賴沖突。BnH28資訊網——每日最新資訊28at.com

3.2、如何排除依賴

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

3.2.1、<exclusions>標簽

Exclusions是主動斷開依賴的資源,被排除的資源無需指定版本—指不需要BnH28資訊網——每日最新資訊28at.com

也就是說可以包含一個或者多 Exclusion 子元素,因此可以排除一個或者多個傳遞性依賴。需要注意的是,聲明 Exclusion 的時候只需要 Groupld 和 Artifactld ,而不需要要 Version 元素。BnH28資訊網——每日最新資訊28at.com

用法示例:BnH28資訊網——每日最新資訊28at.com

<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>標簽

該標簽即是“隱藏依賴”的開關,指對外隱藏當前所依賴的資源---指不透明:BnH28資訊網——每日最新資訊28at.com

  • 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>標簽的區別

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

圖片圖片BnH28資訊網——每日最新資訊28at.com

  • 改為 true 后

圖片圖片BnH28資訊網——每日最新資訊28at.com

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

圖片圖片BnH28資訊網——每日最新資訊28at.com

3.2.3、Maven 聚合工程 統一管理版本

聚合工程,即是指:一個項目允許創建多個子模塊,多個子模塊組成一個整體,可以統一進行項目的構建。要弄明白聚合工程,得先清楚“父子工程”的概念:BnH28資訊網——每日最新資訊28at.com

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

而Maven聚合工程,就是基于父子工程結構,來將一個完整項目,劃分出不同的層次,這種方式可以很好的管理多模塊之間的依賴關系,以及構建順序,大大提高了開發效率、維護性。BnH28資訊網——每日最新資訊28at.com

為了防止不同子工程引入不同版本的依賴,在父工程中,統一對依賴的版本進行控制,規定所有子工程都使用同一版本的依賴,可以使用<dependencyManagement>標簽來管理。BnH28資訊網——每日最新資訊28at.com

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

子工程在使用<dependencyManagement>中已有的依賴項時,不需要寫<version>版本號,版本號在父工程中統一管理,這樣做的好處在于:以后為項目的技術棧升級版本時,不需要單獨修改每個子工程的POM,只需要修改父POM文件即可,減少了版本沖突的可能性。BnH28資訊網——每日最新資訊28at.com

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

如果你的項目中依賴許許多多的 Jar ,肉眼排查就沒那么方便了,這里推薦一個 Maven 管理插件BnH28資訊網——每日最新資訊28at.com

圖片圖片BnH28資訊網——每日最新資訊28at.com

在 Pom 文件中看到 Dependency Analyzer標志,說明 Maven Helper 插件就安裝成功了。BnH28資訊網——每日最新資訊28at.com

圖片圖片BnH28資訊網——每日最新資訊28at.com

點擊 Dependency Analyzer 之后就會進入到下面的頁面BnH28資訊網——每日最新資訊28at.com

圖片圖片BnH28資訊網——每日最新資訊28at.com

從圖中可以看出有哪些jar存在沖突,存在沖突的情況下最終采用了哪個依賴的版本。標紅的就是沖突版本,白色的是當前的解析版本。BnH28資訊網——每日最新資訊28at.com

如果我們想保留標紅的版本,那我們可以標白區域右擊選擇排除(Exclude)即可。BnH28資訊網——每日最新資訊28at.com

5、總結

一般我們在解決依賴沖突的時候,都會選擇保留jar高的版本,因為大部分jar在升級的時候都會做到向下兼容,所以只要保留高的版本就不會有什么問題。BnH28資訊網——每日最新資訊28at.com

但是有些包,版本變化大沒法去做向下兼容,高版本刪了低版本的某些類或者某些方法,那么這個時候就不能一股腦的去選擇高版本,但也不能選擇低版本。BnH28資訊網——每日最新資訊28at.com

就比如下面這個案例BnH28資訊網——每日最新資訊28at.com

依賴鏈路一: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)這樣的話就解決依賴沖突。BnH28資訊網——每日最新資訊28at.com

但話有說回來 A升級到A(2.0) 可能會影響許許多多的地方,比如自己項目中代碼是否需要改變,或者因為 A升級到A(2.0) 導致 B和C的版本有所改變,這些影響點都需要我們去考慮的。所以說為什么說一個大型項目穩定后,Pom文件的升級是件繁瑣的事情,那是因為考慮的東西是在太多了,稍有不慎就會因為依賴沖突而導致系統報錯。BnH28資訊網——每日最新資訊28at.com

本文鏈接:http://m.www897cc.com/showinfo-26-75318-0.html我們一起聊聊 Maven 依賴沖突問題

聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。郵件:2376512515@qq.com

上一篇: 想徒手寫個文件系統?來一起呀

下一篇: 前端視角對Rust的淺析

標簽:
  • 熱門焦點
Top 日韩成人免费在线_国产成人一二_精品国产免费人成电影在线观..._日本一区二区三区久久久久久久久不
久久久亚洲高清| 亚洲激情图片小说视频| 国产精品激情av在线播放| 国产精品国产三级欧美二区 | 国产欧美一区二区三区在线老狼 | 在线高清一区| 亚洲国产一区二区三区a毛片| 日韩一级黄色片| 香蕉久久一区二区不卡无毒影院 | 国产精品国产| 韩国精品在线观看| 亚洲精品中文字幕女同| 亚洲一区尤物| 麻豆精品视频在线观看视频| 欧美日韩国产首页在线观看| 国产日产欧产精品推荐色| 91久久线看在观草草青青| 亚洲一区二区在线| 久久中文字幕一区| 欧美小视频在线观看| 伊人久久婷婷| 亚洲一区二区三区视频播放| 久久一日本道色综合久久| 欧美午夜精品久久久久久孕妇| 国产中文一区| 亚洲视频成人| 免费成人黄色片| 国产精品午夜春色av| 亚洲激情国产| 欧美亚洲网站| 欧美日韩一区二区高清| 国内成人精品2018免费看| 99综合视频| 久久中文在线| 国产欧美日韩不卡| 一本久道久久综合婷婷鲸鱼| 久久久精品一区| 国产精品免费久久久久久| 亚洲国产精品久久久| 欧美一区中文字幕| 欧美喷水视频| 亚洲第一中文字幕| 欧美一区二区三区免费在线看| 欧美日韩激情网| 亚洲高清视频一区| 欧美在线视频观看| 国产精品成人v| 亚洲日本中文字幕| 久久亚洲不卡| 国产日韩综合| 亚洲欧美久久| 欧美日韩国产一中文字不卡| 亚洲电影中文字幕| 久久精品国产在热久久| 国产精品久久久亚洲一区| 99精品国产在热久久下载| 免费久久99精品国产自| 国内精品国产成人| 欧美在线精品免播放器视频| 国产精品久久久久久久久久免费| 亚洲精品综合久久中文字幕| 裸体一区二区| 有坂深雪在线一区| 久久精品一本久久99精品| 国产欧美日韩在线播放| 亚洲综合99| 国产精品黄色| 亚洲一区二区三区在线看| 欧美日本一区二区三区| 91久久夜色精品国产九色| 麻豆久久精品| 亚洲电影第三页| 老司机精品久久| 在线国产亚洲欧美| 久久久久久成人| 国语自产在线不卡| 久久久999精品| 国产亚洲欧洲一区高清在线观看| 欧美一级二级三级蜜桃| 国产精品一区2区| 欧美一级理论性理论a| 国产视频久久久久| 欧美在线一二三区| 国产一区二区三区成人欧美日韩在线观看 | 国产伦精品一区二区三区免费迷| 亚洲影音一区| 国产精品一二三| 欧美一区二区三区免费视| 国产欧美日韩精品一区| 欧美在线3区| 国内精品久久久久久久果冻传媒| 久久九九热免费视频| 好吊色欧美一区二区三区视频| 久久久亚洲国产天美传媒修理工 | 欧美一区观看| 狠狠网亚洲精品| 欧美a级片网| 亚洲免费av电影| 国产精品第一区| 香蕉成人伊视频在线观看| 国产精品一区二区黑丝| 久久福利资源站| 亚洲大胆女人| 欧美欧美天天天天操| 亚洲一区二区三区中文字幕 | 亚洲国产日韩欧美综合久久| 欧美大片va欧美在线播放| 日韩一级视频免费观看在线| 国产精品二区在线| 欧美一二三视频| 亚洲盗摄视频| 欧美视频免费在线| 欧美在线视频a| 亚洲日本中文字幕免费在线不卡| 国产精品99免费看 | 国产一区二区福利| 免费在线看一区| 一区二区三区 在线观看视| 欧美国产日韩一区二区| 99精品热视频只有精品10| 国产精品久久毛片a| 久久精品国产96久久久香蕉| 亚洲福利视频在线| 欧美日韩视频在线一区二区 | 亚洲视频一起| 国产视频一区免费看| 免费不卡在线观看| 亚洲视频你懂的| 伊人久久大香线蕉综合热线| 欧美黄色免费网站| 亚洲自拍另类| 亚洲国产精品久久久久秋霞蜜臀| 欧美日一区二区在线观看| 欧美一区午夜精品| 亚洲精品乱码| 国产日韩一区二区三区| 欧美国产在线电影| 亚洲欧美日韩国产另类专区| 亚洲第一成人在线| 国产精品三区www17con| 欧美成年人在线观看| 亚洲女爱视频在线| 18成人免费观看视频| 国产精品乱子久久久久| 麻豆成人在线播放| 亚洲在线观看视频| 亚洲成色777777在线观看影院| 欧美亚一区二区| 麻豆成人91精品二区三区| 亚洲在线电影| 亚洲每日更新| 韩日欧美一区二区| 国产精品大片| 欧美国产亚洲精品久久久8v| 久久精品国产成人| 一区二区三区视频在线观看| 精品不卡一区二区三区| 国产精品久久77777| 欧美阿v一级看视频| 欧美一区二区日韩| 一本大道av伊人久久综合| 黄色成人在线网址| 国产精品久久777777毛茸茸| 嫩模写真一区二区三区三州| 性色av一区二区怡红| 一本久道久久久| 91久久精品久久国产性色也91| 国产精品日韩专区| 欧美日韩亚洲一区三区| 久久嫩草精品久久久精品| 亚洲午夜激情网页| 亚洲日本成人女熟在线观看| 韩国精品一区二区三区| 国产精品视频免费| 欧美日韩视频一区二区| 免费观看30秒视频久久| 久久精品国产第一区二区三区| 亚洲欧美激情一区| 一区二区三区av| 最新成人av在线| 激情久久久久久久久久久久久久久久| 国产精品美女视频网站| 久久在线精品| 久久久久国内| 久久成人综合网| 亚洲综合日韩在线| 一本色道久久88亚洲综合88| 亚洲日本视频| 亚洲高清在线观看一区| 国内精品伊人久久久久av一坑| 国产精品综合| 国产精品视频第一区| 欧美性jizz18性欧美| 欧美日韩a区| 欧美金8天国| 欧美女主播在线| 欧美日韩国产高清视频| 欧美欧美在线| 欧美精品自拍| 欧美日本中文字幕| 欧美日韩国产a| 欧美日韩高清在线观看| 欧美日韩伦理在线| 欧美片第1页综合|