網上有很多關于maven項目中mirror、profile、repository的搜索順序的文章,說法不一。官方文檔并沒有找到相關的說明,鑒于此,我抽時間做了一個驗證。
依賴倉庫的配置方式
maven項目使用的倉庫一共有如下幾種方式:
如果所有配置都存在,依賴的搜索順序就會變得異常復雜。
分析依賴搜索順序
先從最簡單開始,慢慢增加配置,查看有什么變化。
準備測試環境
安裝jdk、maven。
使用如下命令創建測試項目:
創建完成后,為了避免后續測試干擾,先執行一次compile。
cd mywebmvn 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.12mvn 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.12mvn compile
在日志中查看下載依賴的倉庫:
從顯示的倉庫id可以看出:
配置全局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.12mvn compile -Ps_profile
在日志中查看下載依賴的倉庫:
從顯示的倉庫id可以看出:
配置項目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.12mvn compile -Ps_profile,p_profilemvn compile -Pp_profile,s_profile
在日志中查看下載依賴的倉庫:
從顯示的倉庫id可以看出:
進一步測試:
rm -rf ~/.m2/repository/junit/junit/4.12mvn compile -Pp_profile
在日志中查看下載依賴的倉庫:
從顯示的倉庫id可以看出:
最后確認 local_repo 本地倉庫 ~/.m2/repository
這不算測試了,只是一個結論,可以任意測試。
只要 ~/.m2/repository 中包含依賴,無論怎么配置,都會優先使用local本地倉庫中的jar.
最終結論
通過上面的比較得出完整的搜索鏈:
local_repo > settings_profile_repo > pom_profile_repo > pom_repositories > settings_mirror > central
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VeVb武林網。
新聞熱點
疑難解答
圖片精選