重庆分公司,新征程启航
为企业提供网站建设、域名注册、服务器等服务
网上有很多关于maven项目中mirror、profile、repository的搜索顺序的文章,说法不一。官方文档并没有找到相关的说明,鉴于此,我抽时间做了一个验证。
为积石山保安族东乡族等地区用户提供了全套网页设计制作服务,及积石山保安族东乡族网站建设行业解决方案。主营业务为网站设计、成都网站制作、积石山保安族东乡族网站设计,以传统方式定制建设网站,并提供域名空间备案等一条龙服务,秉承以专业、用心的态度为用户提供真诚的服务。我们深信只要达到每一位用户的要求,就会得到认可,从而选择与我们长期合作。这样,我们也可以走得更远!
依赖仓库的配置方式
maven项目使用的仓库一共有如下几种方式:
如果所有配置都存在,依赖的搜索顺序就会变得异常复杂。
分析依赖搜索顺序
先从最简单开始,慢慢增加配置,查看有什么变化。
准备测试环境
安装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_mirror https://maven.aliyun.com/repository/public central
重新测试:
rm -rf ~/.m2/repository/junit/junit/4.12 mvn compile
在日志中查看下载依赖的仓库:
可以看出,是从 settings_mirror 中下载的jar
结论:settings_mirror 的优先级高于 central
配置pom中的仓库 pom_repositories
在 project 中增加如下配置:
pom_repositories local http://10.18.29.128/nexus/content/groups/public/ true true
由于我们改变了id的名字,所以仓库地址无所谓,使用相同的地址也不影响测试。
执行测试:
rm -rf ~/.m2/repository/junit/junit/4.12 mvn compile
在日志中查看下载依赖的仓库:
从显示的仓库id可以看出:
配置全局profile仓库 settings_profile_repo
在 ~/.m2/settings.xml 中 settings 的节点内增加:
s_profile settings_profile_repo netease http://mirrors.163.com/maven/repository/maven-public/ true true
执行测试:
rm -rf ~/.m2/repository/junit/junit/4.12 mvn compile -Ps_profile
在日志中查看下载依赖的仓库:
从显示的仓库id可以看出:
配置项目profile仓库 pom_profile_repo
p_profile pom_profile_repo local http://10.18.29.128/nexus/content/groups/public/ true true
执行测试:
rm -rf ~/.m2/repository/junit/junit/4.12 mvn compile -Ps_profile,p_profile mvn compile -Pp_profile,s_profile
在日志中查看下载依赖的仓库:
从显示的仓库id可以看出:
进一步测试:
rm -rf ~/.m2/repository/junit/junit/4.12 mvn 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
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持创新互联。