一、简介
1.1 作用
将pom工程父子pom的版本,提出作为变量定义在properties。
这样仅修改变量的值(如在运行mvn命令时指定) 即可实现版本整体切换
1.2 goal介绍
- flatten:clean
删除flatten插件生成的 .flattened-pom.xml
配置参数有:
flattenedPomFilename: 插件生成的pom的名字,默认为
.flattened-pom.xml
outputDirectory:插件生成pom的目录,默认为 ${project.basedir}
- flatten:flatten
在resources-process
生成 .flattened-pom.xml
,并在install/deploy时替换原始pom.xml
主要配置参数有:
flattenedPomFilename: 插件生成的pom的名字,默认为
.flattened-pom.xml
outputDirectory:插件生成pom的目录,默认为 ${project.basedir}
updatePomFile: packing=pom的module也进行reversion变量替换,默认为false
flattenMode:用来定义生成
.flattened-pom.xml
所包含的元素,常用值有:
oss:开源软件常用,除了repositories/pluginRepositories外其他所有FlattenDescriptor定义的元素都生成
ossrh:所有FlattenDescriptor定义的元素都生成
bom:在ossrh基础上增加dependencyManagement和properties
defaults:除了repositories其他所有FlattenDescriptor定义的元素都不生成
clean:所有FlattenDescriptor定义的元素都不生成
fatjar:所有FlattenDescriptor定义的元素和dependencies都不生成
resolveCiFriendliesOnly:只替换原始pom中的revision, sha1 and changelist,其他否保持原样
常用oss/ossrh/resolveCiFriendliesOnly
- FlattenDescriptor定义的pom.xml元素有:
modelVersion
groupId
artifactId
version
packaging
licenses
dependencies
profiles
name
description
url
inceptionYear
organization
scm
developers
contributors
mailingLists
pluginRepositories
issueManagement
ciManagement
distributionManagement
prerequisites
repositories
parent
build
dependencyManagement
properties
modules
reporting
二、使用总结
- 不用flatten-maven-plugin
1.父pom定义版本为变量reversion并作为version,子pom复引用变量reversion作为version
2.结果能正常运行compile/test, 但install或deploy时父子pom中的version还是reversion变量未被替换
3.没有version别人无法引用你的包
父pom.xml
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<packaging>pom</packaging>
<version>${reversion1}</version>
<modules>
<module>no-flatten-child</module>
</modules>
<groupId>com.wsl.my.maven</groupId>
<artifactId>no-flatten-plugin</artifactId>
<properties>
<maven.compiler.source>8</maven.compiler.source>
<maven.compiler.target>8</maven.compiler.target>
<reversion1>1.1.0-SNAPSHOT</reversion1>
</properties>
</project>
子pom.xml
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<parent>
<artifactId>no-flatten-plugin</artifactId>
<groupId>com.wsl.my.maven</groupId>
<version>${reversion1}</version>
<relativePath>../pom.xml</relativePath>
</parent>
<modelVersion>4.0.0</modelVersion>
<artifactId>no-flatten-child</artifactId>
</project>
install/deploy后父子pom.xml中的${reversion1}没有被替换
- 使用了flatten-maven-plugin
1.父pom定义版本为变量reversion并作为version,子pom复引用变量reversion作为version
2.使用flatten-maven-plugin并设置updatePomFile=true,并绑定goal到maven周期
3.在process-resources阶段时会在父子project目录下生成.flattened-pom.xml(version已替换为具体值)
4.运行install或deploy时会将.flattened-pom.xml替换原来的pom.xml
原始父pom
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<version>${reversion2}</version>
<packaging>pom</packaging>
<artifactId>use-flatten-parent</artifactId>
<groupId>com.wsl.my.maven</groupId>
<modules>
<module>use-flatten-child</module>
</modules>
<properties>
<maven.compiler.source>8</maven.compiler.source>
<maven.compiler.target>8</maven.compiler.target>
<reversion2>1.2.0-SNAPSHOT</reversion2>
</properties>
<build>
<plugins>
<plugin>
<groupId>org.codehaus.mojo</groupId>
<artifactId>flatten-maven-plugin</artifactId>
<version>1.2.7</version>
<configuration>
<updatePomFile>true</updatePomFile>
<flattenMode>resolveCiFriendliesOnly</flattenMode>
</configuration>
<executions>
<execution>
<id>flatten</id>
<phase>process-resources</phase>
<goals>
<goal>flatten</goal>
</goals>
</execution>
<execution>
<id>flatten-clean</id>
<phase>clean</phase>
<goals>
<goal>clean</goal>
</goals>
</execution>
</executions>
</plugin>
</plugins>
</build>
</project>