最近一个maven多模块的旧项目接手后,由于模块过多,父pom更新版本后,需要手动修改每个模块的父pom版本,这个可以使用versions插件,使用说明可以参考官方文档
先引入了插件包
<plugin>
<groupId>org.codehaus.mojo</groupId>
<artifactId>versions-maven-plugin</artifactId>
<version>2.2</version>
</plugin>
但执行完以下命令,坑就出来了
mvn versions:set -DnewVersion=1.0.1-SNAPSHOT
执行后一直提示
Could not find goal 'set' in plugin com.xxx.maven.plugins:maven-versions-plugin:1.0.0-SNAPSHOT among available goals merge-execute, gen -> [Help 1]
仔细看了下,这个插件虽然是maven-versions-plugin,但是groupId是公司的一个内部包前缀,而不是我引入的org.codehaus.mojo。
第一想到的是这个jar包可能来源于父pom,但是查看了父pom,并没有发现有引入插件。
这时想,就算没有,干脆通过其他方式直接把 com.xxx.maven.plugins包的maven-versions-plugin的插件禁用算了,org.codehaus.mojo包下的maven-versions-plugin不就可以执行了吗。
这里按照这篇Maven中如何禁止插件(plugin)在子模块(module)上执行
在pom中加入了
<plugin>
<groupId>com.xxx.maven.plugins</groupId>
<artifactId>maven-versions-plugin</artifactId>
<version>1.0.0-SNAPSHOT</version>
<executions>
<execution>
<id>default-jar</id>
<phase>none</phase>
</execution>
</executions>
</plugin>
尝试强制禁用。
但是执行完mvn versions:set后,依然提示同样的错误信息
这时候,仔细检查了当前项目pom,父pom,确实没有发现任何地方有引入com.xxx.maven.plugins包前缀的插件。
难道是全局的setting.xml文件里定义了插件?
这时,打开setting.xml,发现了这样一段配置
<pluginGroups>
<pluginGroup>com.xxx.org.apache.maven.plugins</pluginGroup>
<pluginGroup>com.xxx.maven.plugins</pluginGroup>
</pluginGroups>
恍然大悟,原来是这里替换掉了插件的groupId,注释掉后,versions插件可以正常使用。