1. 程式人生 > 程式設計 >maven解決包衝突方法詳解

maven解決包衝突方法詳解

Maven根據最近勝利策略(nearest wins strategy)的原則工作,同時解決依賴衝突,這意味著它在依賴樹中找到更接近的版本,它將採用該版本並忽略其他版本。實際上Maven有點懶,所以每當它開始尋找依賴時,它就會從根目錄開始遍歷樹,無論它先前找到哪個版本,它都會選擇它並從它們返回而不進一步。如果它進一步尋找依賴版本,可能會有機找到一些更新的版本,但它從第一個發現的版本那裡返回,並採用舊版本並用它來解決依賴關係。

可以用下面的命令顯示依賴樹:

mvn dependency:tree

老實說,這不是maven的錯,因為它想盡快完成這項工作。最重要的是,maven 不知道你的應用程式期望哪個版本,所以Maven會告訴你,嘿,你有責任讓我知道你想要哪個版本,如果你不告訴我,我會以自己的方式工作,即更近更好。

請下載本文的github原始碼:

https://github.com/yujiaao/maven-dependency-conflict-demo

我們有一個 web 應用 resolve-web,該工程依賴於 project-A 和project-B,project-A 依賴於 project-common 的 1.0 版本並呼叫其中的 sayHello() 方法。project-B 依賴於project-C,而project-C又進一步依賴於project-common的2.0 版本並呼叫其中的 sayGoodBye() 方法。project-common 的 1.0 和 2.0 版本是不同的,1.0 中之包含sayHello() 方法,而2.0 中包含了sayHello()和sayGoodBye()兩個方法。整個專案的依賴關係如下圖:

根據Maven的transitive依賴機制,resolve-web 將同時依賴於project-common 的 1.0 和 2.0 版本,這就造成了依賴衝突。而根據最近獲勝策略,Maven 將選擇 project-common 的 1.0 版本作為最終的依賴。

這和 Gradle 不同,Gradle 在預設情況下將選擇最新的版本作為獲勝版本。

而對於Maven,由於proejct-common的1.0版本比2.0版本在依賴樹中離resolve-web更近,故 1.0 版本獲勝。在 resolve-web 中執行mvn dependency:tree -Dverbose 可以看到 resolve-web 的依賴關係:

[INFO] resolve-web:resolve-web:war:1.0-SNAPSHOT
[INFO] +- junit:junit:jar:3.8.1:test
[INFO] +- project-B:project-B:jar:1.0:compile
[INFO] | \- project-C:project-C:jar:1.0:compile
[INFO] |   \- (project-common:project-commmon:jar:2.0:compile - omitted for conflict with 1.0)
[INFO] +- project-A:project-A:jar:1.0:compile
[INFO] | \- project-common:project-commmon:jar:1.0:compile
[INFO] \- javax.servlet:servlet-api:jar:2.4:provided

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支援我們。