Maven does not replace a variable in 'settings.xml' when it is invoked

流过昼夜 提交于 2019-12-12 08:47:09

问题


I have defined a local mirror for all repositories in the settings.xml file:

<mirror>
  <id>myMirror</id>
  <mirrorOf>*</mirrorOf>
  <url>file://${mypath}/maven/.m2/repository</url>
</mirror>

I want that my mirror to point to a local path, in this case the path is:

file://${mypath}/maven/.m2/repository

Where ${mypath} is a variable that I pass when I invoke Maven:

 mvn -Dmypath="/D:/test" package

The problem is that Maven does not replace the variable when it is invoked. I can see that this error is happening by inspection of the build log. For example, Maven reports that it is downloading a file from file://${mypath}/maven/.m2/repository when the correct would be file:///D:/test/maven/.m2/repository.

I have also noted that Maven replaces correctly my variable when it is inserted in the url child tag of the repository tag:

<repository>
        <id>central</id>
        <url>http://${mypath}/maven/.m2/repository</url>
</repository>

The build works correctly when I replace the variable in my settings.xml by the complete URL like in the example below:

<mirror>
        <id>myMirror</id>
        <mirrorOf>*</mirrorOf>
        <url>file:///D:test/maven/.m2/repository</url>
</mirror>

回答1:


Property substitution into settings.xml doesn't work as you would expect.

It will substitute properties inside the profiles element (as you've seen it substitutes into your repository url, which would be defined inside a profile), but not to elements outside of profiles (as you've seen happening in the mirrors section). This distinction is made because the profile element in the settings.xml is a truncated version of the pom.xml profile element. It is a mechanism to allow configuration to be set into your POM, so property substitution is allowed within the profiles elements as they are effectively part of the POM.

The parts of the settings outside of the profiles element represent the platform configuration, these aren't supposed to be affected by individual builds, so are not substituted for command-line properties. This makes sense but isn't really made clear anywhere.

EDIT: in the settings page of mavens documentation, in the last sentence of the quick overview section (quite hidden) it states:

Note that properties defined in profiles within the settings.xml cannot be used for interpolation.


There is a workaround though, you can substitute environment variables into the settings.xml. If you set the environment variable:

set M2_MIRROR=D:\test

and configure the repository url as follows:

<url>file://${M2_MIRROR}/maven/.m2/repository</url>

Then invoke Maven as normal, the environment variable is substituted and your build should work as required.




回答2:


This is an old question now, but as of Maven 3, and probably before, you can refer to environment vars, if you prefix with 'env'

I do so like this:

  <localRepository>${env.M2_LOCAL_REPO}</localRepository>

Then each developer sets M2_LOCAL_REPO to an appropriate location.




回答3:


The settings.xml is not interpolated like the pom is, so the property can't be used like shown above.




回答4:


It is probably a bug - unfortunately property replacement does not seem to be consistent across Maven plugins. I have encountered a bug myself around specifying more than two properties in a configuration item in another plugin.



来源:https://stackoverflow.com/questions/1363514/maven-does-not-replace-a-variable-in-settings-xml-when-it-is-invoked

标签
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!