neverend的日志

          不記錄,終將被遺忘。 一萬年太久,只爭朝夕。 他們用數字構建了整個世界。

            BlogJava :: 首頁 :: 聯系 :: 聚合  :: 管理
            62 Posts :: 1 Stories :: 17 Comments :: 0 Trackbacks
          項目開發過程中經常會碰到maven依賴沖突的問題,這篇post整理下maven依賴沖突產生的原因以及解決方案

          maven依賴沖突的產生是由maven傳遞性依賴造成的:

          什么是maven傳遞依賴?
          “一個傳遞性依賴就是對于一個依賴的依賴。如果project-a依賴于project-b,而后
          者接著依賴于project-c,那么project-c就被認為是project-a的傳遞性依賴。如
          果project-c依賴于project-d,那么project-d就也被認為是project-a的傳遞性依
          賴。Maven的部分吸引力是由于它能夠管理傳遞性依賴,并且能夠幫助開發者屏蔽掉跟
          蹤所有編譯期和運行期依賴的細節。你可以只依賴于一些包如Spring Framework,而不
          用擔心Spring Framework的所有依賴,Maven幫你自動管理了,你不用自己去詳細了解
          配置。
          Maven是怎樣完成這件事情的呢?它建立一個依賴圖,并且處理一些可能發生的沖突和
          重疊。例如,如果Maven看到有兩個項目依賴于同樣的groupId和artifactId,它會自動
          整理出使用哪個依賴,選擇那個最新版本的依賴。雖然這聽起來很方便,但在一些邊界
          情況中,傳遞性依賴會造成一些配置問題。在這種情況下,你可以使用依賴排除。”
                                                                       ——摘自《Maven權威指南》

          什么情況下會產生依賴沖突?
          舉例說明:項目中的pom.xml里聲明了對project-a1.0與project-b2.0的依賴,而project-a1.0又傳遞依賴于project-b1.0的版本。
          假設maven經過分析之后決定使用project-b1.0的依賴,也就是打包的時候把project-b1.0.jar打進了war包。
          war包部署在java容器中啟動之后,如果依賴project-b2.0.jar中新添的類或方法,就會發現引用的類或者方法不存在。
          這種現象就是依賴沖突。

          如何分析依賴沖突?
          mvn dependency:tree

          沖突解決方案:
          使用maven提供的<exclusion>標簽。
          舉例說明:
          如果你正依賴于一個類庫,該類庫又依賴于Sun JTA API,你會想要替換這個傳遞性依賴。
          Hibernate是一個例子。Hibernate依賴于Sun JTA API,而后者在中央Maven倉庫中不可用,因為它是不
          能免費分發的。幸運的是,Apache Gernoimo項目創建了一些可以免費分發的獨立實現
          類庫。為了用另外的依賴來替換這個傳遞性依賴,你需要排除這個傳遞性以依賴,然后
          在你的項目中再聲明一個依賴。下面展示了這樣一個替換的樣例。
          <dependency>
              
          <groupId>org.hibernate</groupId>
              
          <artifactId>hibernate</artifactId>
              
          <version>3.2.5.ga</version>
              
          <exclusions>
                  
          <exclusion>
                      
          <groupId>javax.transaction</groupId>
                      
          <artifactId>jta</artifactId>
                  
          </exclusion>
              
          </exclusions>
          </dependency>
          <dependency>
              
          <groupId>org.apache.geronimo.specs</groupId>
              
          <artifactId>geronimo-jta_1.1_spec</artifactId>
              
          <version>1.1</version>
          </dependency>


          posted on 2012-02-03 15:51 neverend 閱讀(1970) 評論(1)  編輯  收藏 所屬分類: 工具技巧

          Feedback

          # re: maven依賴沖突[未登錄] 2014-01-22 14:11 daniel
          恩,總結的不錯。 通過mvn dependency:tree 找出沖突的依賴包,然后通過mvn的exclude或者直接引入maven依賴來解決依賴沖突 http://www.daniel-journey.com/archives/1125  回復  更多評論
            


          只有注冊用戶登錄后才能發表評論。


          網站導航:
           
          主站蜘蛛池模板: 彭山县| 临邑县| 宝兴县| 洛南县| 大足县| 无为县| 卓尼县| 监利县| 宁蒗| 葫芦岛市| 固阳县| 东乡县| 新田县| 马山县| 楚雄市| 蒙山县| 三门峡市| 新野县| 谷城县| 张家港市| 鄂伦春自治旗| 彭泽县| 齐齐哈尔市| 呼伦贝尔市| 淄博市| 富裕县| 青海省| 独山县| 齐齐哈尔市| 轮台县| 眉山市| 阿城市| 那曲县| 云霄县| 盐池县| 抚顺市| 改则县| 寻甸| 东城区| 兰考县| 靖西县|