关于maven读取settings.xml文件的优先级问题

今天在IDEA中配置maven的setting.xml文件路径指向的.m2路径下的setting_a.xml文件,同时,我的maven3.6.3也放在.m2中。

[1] .m2文件夹

[2] apache-maven-3.6.3文件夹

然后,在IDEA中打包发布时发现,无论如何都读取不到指定的setting_a.xml文件。这个IDEA内指向的settings_a.xml不生效,依赖无法上传到指定仓库中。

这个应该是maven加载setting.xml文件优先级的问题了,去maven官网看了下,有详细介绍。

[3] 官网关于读取setting.xml文件优先级

maven官网关于maven加载setting.xml文件优先级的介绍:

翻译:

快速概览

文件中的元素包含使用的元素 定义以各种方式配置 Maven 执行的值,例如 ,但不应捆绑到任何特定项目,或者 分发给观众。这些值包括 local 存储库位置、备用远程存储库服务器和 身份验证信息。settings``settings.xml``pom.xml

文件可能位于两个位置:settings.xml

  • Maven 安装:${maven.home}/conf/settings.xml

  • 用户的安装:${user.home}/.m2/settings.xml

前者也称为全局设置,后者称为用户设置。如果这两个文件都存在, 它们的内容被合并,用户特定的是 主导。settings.xml``settings.xml``settings.xml

提示:如果您需要从头开始创建特定于用户的设置,则 最简单的方法是将全局设置从 Maven 安装复制到目录。Maven 的默认值是 带有注释和示例的模板,以便您可以快速调整它以匹配 您的需求。${user.home}/.m2``settings.xml

以下是以下主要元素的概述:settings

<settings xmlns="http://maven.apache.org/SETTINGS/1.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/SETTINGS/1.0.0 https://maven.apache.org/xsd/settings-1.0.0.xsd">
<localRepository/>
<interactiveMode/>
<offline/>
<pluginGroups/>
<servers/>
<mirrors/>
<proxies/>
<profiles/>
<activeProfiles/>
</settings>

可以使用 以下表达式:settings.xml

  1. ${user.home}和所有其他系统属性*(从 Maven 3.0 开始)*

  2. ${env.HOME}等用于环境变量

请注意,在配置文件中定义的属性不能用于插值。settings.xml

它的大概意思是:

settings.xml可能存在两个文件夹:

  1. Maven安装目录:${M2_HOME}/conf/settings.xml

  2. 用户的.m2目录:${user.home}/.m2/settings.xml

1是全局配置,2是用户配置。如果两者都存在,它们的内容将被合并,并且用户目录的settings.xml优先。

加载setting.xml的优先级如下:

  1. ${user.home}/.m2 目录下读取 settings.xml

  2. ${user.home}/.m2目录下不存在settings.xml时,从{M2_HOME}/conf 目录下读取

  3. idea界面里开发手动指定的settings.xml

[4] 解决读取指定setting.xml失败的解决方式

方式1:将.m2内的setting_a.xml文件名修改为settings.xml的文件,发布jar包成功(但是IDEA中继续使用.m2/setting_a.xml这个路径配置不生效的,文件找不到)。

方式2:将.m2内的setting_a.xml文件名不动,直接去删掉maven3.6.3的conf目录内的setting.xml文件,发布成功。

方式3:删除.m2内的setting_a.xml文件,将该文件修改为settings.xml放入maven3.6.3的conf目录内,虽然也能发布jar成功,但是IDEA中配置的.m2/setting_a.xml这个路径配置不生效的,使用的是系统变量内的setting.xml文件。

所以,暴力点,直接删除.m2内的setting文件,环境和IDEA工具均统一去使用maven3.6.3的conf目录下setting配置。

Done

相关推荐
码农小旋风1 小时前
IDEA 不只接 Claude 和 Codex:本地模型和第三方 API 也能直接用
java·ide·人工智能·chatgpt·intellij-idea·claude
徐先生 @_@|||1 小时前
pycharm/IDEA + markdown + 图床(PicList)
ide·python·pycharm·intellij-idea
之歆2 小时前
Claude Code 多账号体系实战:终端别名、脚本与 IDEA CC GUI 切换指南
java·ide·intellij-idea
我是一颗柠檬3 小时前
【JDK8新特性】接口默认方法与静态方法Day8
java·开发语言·后端·intellij-idea
吱奇物语4 小时前
Maven高级—分模块设计与开发、继承、聚合和私服
java·maven
野生技术架构师4 小时前
IDEA Maven 手动替换第三方Jar包完整教程
maven·intellij-idea·jar
程序猿七度4 小时前
IDEA2026.1中配置Codex(非官方订阅-针对国内走中转路线NewApi)
java·intellij-idea·codex·newapi
基哥的奋斗历程4 小时前
Maven install Java.lang.StackOverflowError
java·开发语言·maven
方也_arkling4 小时前
【Java-Day01】安装软件并修改基础配置项
java·ide·intellij-idea
yanghuashuiyue1 天前
关于Eclipse和IDEA对比
java·ide·intellij-idea