這篇文章主要介紹了淺談Maven 項目中依賴的搜索順序,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
網上有很多關於maven項目中mirror、profile、repository的搜索順序的文章,說法不一。官方文檔並沒有找到相關的說明,鑑於此,我抽時間做了一個驗證。
依賴倉庫的配置方式
maven項目使用的倉庫一共有如下幾種方式:
- 中央倉庫,這是默認的倉庫
- 鏡像倉庫,通過 sttings.xml 中的 settings.mirrors.mirror 配置
- 全局profile倉庫,通過 settings.xml 中的 settings.repositories.repository 配置
- 項目倉庫,通過 pom.xml 中的 project.repositories.repository 配置
- 項目profile倉庫,通過 pom.xml 中的 project.profiles.profile.repositories.repository 配置
- 本地倉庫
如果所有配置都存在,依賴的搜索順序就會變得異常複雜。
分析依賴搜索順序
先從最簡單開始,慢慢增加配置,查看有什麼變化。
準備測試環境
安裝jdk、maven。
使用如下命令創建測試項目:
創建完成後,爲了避免後續測試干擾,先執行一次compile。
cd myweb mvn compile
最後,修改 pom.xml 文件,將 junit版本號改爲 4.12 。我們要使用這個jar來測試依賴的搜索順序。
默認情況
首先確保junit4.12不存在:
rm -rf ~/.m2/repository/junit/junit/4.12
默認情況下沒有配置任何倉庫,也就是說,既沒改 $M2_HOME/conf/settings.xml 也沒有添加 ~/.m2/settings.xml
執行編譯,查看日誌中拉取junit的倉庫。
mvn compile ... Downloaded from central: https://repo.maven.apache.org/maven2/junit/junit/4.12/junit-4.12.pom (24 kB at 11 kB/s)
可以看出,默認是從 central 中央倉庫拉取的jar.
配置鏡像倉庫 settings_mirror
創建 ~/.m2/setttings.xml ,內容如下:
<settings> <mirrors> <mirror> <id>settings_mirror</id> <url>https://maven.aliyun.com/repository/public</url> <mirrorOf>central</mirrorOf> </mirror> </mirrors> </settings>
重新測試:
rm -rf ~/.m2/repository/junit/junit/4.12 mvn compile
在日誌中查看下載依賴的倉庫:
可以看出,是從 settings_mirror 中下載的jar
結論:settings_mirror 的優先級高於 central
配置pom中的倉庫 pom_repositories
在 project 中增加如下配置:
<repositories> <repository> <id>pom_repositories</id> <name>local</name> <url>http://10.18.29.128/nexus/content/groups/public/</url> <releases> <enabled>true</enabled> </releases> <snapshots> <enabled>true</enabled> </snapshots> </repository> </repositories>
由於我們改變了id的名字,所以倉庫地址無所謂,使用相同的地址也不影響測試。
執行測試:
rm -rf ~/.m2/repository/junit/junit/4.12 mvn compile
在日誌中查看下載依賴的倉庫:
從顯示的倉庫id可以看出:
- jar 是從 pom_repositories 中下載的。
- pom_repositories 優先級高於 settings_mirror
配置全局profile倉庫 settings_profile_repo
在 ~/.m2/settings.xml 中 settings 的節點內增加:
<profiles> <profile> <id>s_profile</id> <repositories> <repository> <id>settings_profile_repo</id> <name>netease</name> <url>http://mirrors.163.com/maven/repository/maven-public/</url> <releases> <enabled>true</enabled> </releases> <snapshots> <enabled>true</enabled> </snapshots> </repository> </repositories> </profile> </profiles>
執行測試:
rm -rf ~/.m2/repository/junit/junit/4.12 mvn compile -Ps_profile
在日誌中查看下載依賴的倉庫:
從顯示的倉庫id可以看出:
- jar 是從 settings_profile_repo 中下載的。
- settings_profile_repo 優先級高於 settings_mirror。
- settings_profile_repo 優先級高於 pom_repositories 。
配置項目profile倉庫 pom_profile_repo
<profiles> <profile> <id>p_profile</id> <repositories> <repository> <id>pom_profile_repo</id> <name>local</name> <url>http://10.18.29.128/nexus/content/groups/public/</url> <releases> <enabled>true</enabled> </releases> <snapshots> <enabled>true</enabled> </snapshots> </repository> </repositories> </profile> </profiles>
執行測試:
rm -rf ~/.m2/repository/junit/junit/4.12 mvn compile -Ps_profile,p_profile mvn compile -Pp_profile,s_profile
在日誌中查看下載依賴的倉庫:
從顯示的倉庫id可以看出:
- jar 是從 settings_profile_repo 中下載的
- settings_profile_repo 優先級高於 pom_profile_repo
進一步測試:
rm -rf ~/.m2/repository/junit/junit/4.12 mvn compile -Pp_profile
在日誌中查看下載依賴的倉庫:
從顯示的倉庫id可以看出:
- jar 是從 settings_profile_repo 中下載的
- pom_profile_repo 優先級高於 pom_repositories
最後確認 local_repo 本地倉庫 ~/.m2/repository
這不算測試了,只是一個結論,可以任意測試。
只要 ~/.m2/repository 中包含依賴,無論怎麼配置,都會優先使用local本地倉庫中的jar.
最終結論
- settings_mirror 的優先級高於 central
- settings_profile_repo 優先級高於 settings_mirror
- settings_profile_repo 優先級高於 pom_repositories
- settings_profile_repo 優先級高於 pom_profile_repo
- pom_profile_repo 優先級高於 pom_repositories
- pom_repositories 優先級高於 settings_mirror
通過上面的比較得出完整的搜索鏈:
local_repo > settings_profile_repo > pom_profile_repo > pom_repositories > settings_mirror > central
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持神馬文庫。