1、何為依賴沖突
maven是個很好用的依賴管理工具,但是再好的東西也不是完美的。maven的依賴機制會導致jar包的沖突。舉個例子,現在你的項目中,使用了兩個jar包,分別是a和b。現在a需要依賴另一個jar包c,b也需要依賴c。但是a依賴的c的版本是1.0,b依賴的c的版本是2.0。這時候,maven會將這1.0的c和2.0的c都下載到你的項目中,這樣你的項目中就存在了不同版本的c,這時maven會依據依賴路徑最短優先原則,來決定使用哪個版本的jar包,而另一個無用的jar包則未被使用,這就是所謂的依賴沖突。
在大多數時候,依賴沖突可能并不會對系統造成什么異常,因為maven始終選擇了一個jar包來使用。但是,不排除在某些特定條件下,會出現類似找不到類的異常,所以,只要存在依賴沖突,在我看來,最好還是解決掉,不要給系統留下隱患。
2、解決方法
解決依賴沖突的方法,就是使用maven提供的<exclusion>標簽,<exclusion>標簽需要放在<exclusions>標簽內部,就像下面這樣:
1
2
3
4
5
6
7
8
9
10
11
|
<dependency> <groupid>org.apache.logging.log4j</groupid> <artifactid>log4j-core</artifactid> <version> 2.10 . 0 </version> <exclusions> <exclusion> <artifactid>log4j-api</artifactid> <groupid>org.apache.logging.log4j</groupid> </exclusion> </exclusions> </dependency> |
log4j-core
本身是依賴了log4j-api
的,但是因為一些其他的模塊也依賴了log4j-api
,并且兩個log4j-api
版本不同,所以我們使用<exclusion>標簽排除掉log4j-core
所依賴的log4j-api
,這樣maven就不會下載log4j-core
所依賴的log4j-api
了,也就保證了我們的項目中只有一個版本的log4j-api
。
3、maven helper
看到這里,你可能會有一個疑問。如何才能知道自己的項目中哪些依賴的jar包沖突了呢?maven helper這個intelij idea的插件幫我們解決了這個問題。插件的安裝方法我就不講了,既然你都會maven了,我相信你也是會安裝插件的。
在插件安裝好之后,我們打開pom.xml文件,在底部會多出一個dependency analyzer選項
點開這個選項
找到沖突,點擊右鍵,然后選擇exclude即可排除沖突版本的jar包。
4、小技巧
除了使用maven helper查看依賴沖突,也可以使用idea提供的方法——maven依賴結構圖,打開maven窗口,選擇dependencies,然后點擊那個圖標(show dependencies)或者使用快捷鍵(ctrl+alt+shift+u),即可打開maven依賴關系結構圖
在圖中,我們可以看到有一些紅色的實線,這些紅色實線就是依賴沖突,藍色實線則是正常的依賴。
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持服務器之家。
原文鏈接:https://segmentfault.com/a/1190000017542396