Maven是個很好用的依賴管理工具,但是再好的東西也不是完美的。 ...
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>標簽內部,就像下麵這樣:
<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
● 你連微服務的網關都說不清楚,還天天鼓搗著要把項目拆分微服務?