我真正建议的第一件事是重新构造项目文件夹…这意味着让项目文件夹代表结构,这意味着 不要 展平结构。
+-- parent-pom (pom.xml) +--- module1 (pom.xml) +--- module2 (pom.xml) +--- module3 (pom.xml)
结果,您的父级的模块部分将被简化为:
<modules> <module>module1</module> <module>module2</module> <module>module3</module></modules>
此外,可以简化模块中的父条目,如下所示:
<parent> <groupId>com.cws.cs.lendingsimulationservice</groupId> <artifactId>parent-pom</artifactId> <version>1.0.6</version></parent>
…将我带到下一点:
如果您当前的所有项目都按上述方式定义了其父级,则这是完全错误的,cause将尝试在存储库中而不是上级文件夹中找到父级。换句话说,这会导致您在发布等方面出现很多问题。
如果我们要解决此问题,它必须看起来像这样,我不建议这样做:
<parent> <groupId>com.cws.cs.lendingsimulationservice</groupId> <artifactId>parent-pom</artifactId> <version>1.0.6</version> <relativePath>../parent-pom/pom.xml</relativePath></parent>
我观察到的另一件事是您不使用
SNAPTSHOT,在发布阶段,该插件将由发布插件取代。与此相关的是,它将自动更改相应父级中的所有版本。
在理想情况下,您的模块应如下所示:
<parent> <groupId>com.cws.cs.lendingsimulationservice</groupId> <artifactId>parent-pom</artifactId> <version>1.0.6</version></parent><artifactId>module-1</artifactId><!-- No Version or groupId -->
因为所有模块都
groupId将从其父级继承该版本。有时更改模块很有用或需要,
groupId但这是一个例外。
我重读的是关于父级的单独版本控制。这根本没有意义,因为它是其模块的父级,因此将其放入相同的结构,当然也放入相同的VCS。
如果要制作一些配置/插件版本,则应将依赖性用于其他项目,而不是创建一个单独的公司
pom.xml,该公司是一个单独的项目,并将单独发布等。
完成结构更改后,您可以简单地进入parent-pom目录并从该文件夹执行操作
mvn clean package或
mvn release:preparerelease:perform从该文件夹进行操作,一切将变得更加简单。



