博主工作负责的微服务已经达到了十几个,每个微服务相互直接都是独立的,有独立的project,于是maven的依赖管理就很头疼了。每一个项目都需要添加自己的版本,还要互相比对,每次升级一些第三方依赖需要修改所有文件,于是产生了自己写parent的想法。
访问我的个人网站获取更多文章
第一种思路是:自己写一个parent pom,使用dependencyManagement管理所有依赖的版本,通过maven install安装到本地仓库。之后在使用的地方设置parent为之前写的即可。
但是这样做存在一个问题,我使用了spring-boot-starter-parent, maven只允许存在一个parent。当然可以通过在项目中使用dependencyManagement解决,但是我想统一到一起管理。
第二个思路:将自己写的parent pom的parent设置为spring-boot-starter-parent即可解决上一个问题。注意:dependencyManagement中出现的每一个依赖,必须写明版本。当我的项目继承自己的parent的时候,也自动的继承了spring-boot-starter-parent,所以,依赖于spring-boot-starter-parent提供版本的项目,不比再写到dependencyManagement中。
思路二的问题是:我所有项目没有采用spring-boot-starter-web提供的tomcat容器,而是使用了jetty,包括我很多项目使用了一些相同的依赖,是否可以将这些依赖组合在一起,简化我的配置呢?
简而言之,我想做一个和spring一样的pom version管理。通过搜索和阅读maven的文档,我发现了一个概念:bom
bom:bill of materials,直译过来是物料清单,我们通过bom的方式构建自己的依赖管理。
新建一个maven项目,pom.xml文件即我们的bom文件。
我们在bom文件中管理所有的子依赖集合项目,其本身不负责依赖版本的管理。bom文件的packaging属性为pom,dependencyManagement包含了所有的子依赖集合项目。
<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.0modelVersion>
<groupId>com.testgroupId>
<artifactId>bomartifactId>
<version>1.0.0version>
<packaging>pompackaging>
<properties>
<project1Version>1.0.0project1Version>
<project2Version>1.0.0project2Version>
properties>
<dependencyManagement>
<dependencies>
<dependency>
<groupId>com.testgroupId>
<artifactId>project1artifactId>
<version>${project1Version}version>
dependency>
<dependency>
<groupId>com.testgroupId>
<artifactId>project2artifactId>
<version>${project1Version}version>
dependency>
dependencies>
dependencyManagement>
<modules>
<module>parentmodule>
modules>
project>
创建一个子模块,parent为bom,这个模块负责所有的版本管理。在我的实际情况中,由于该文件已经有了parent,所以我把spring的parent也放在了dependencyManagement中。
<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.0modelVersion>
<parent>
<groupId>com.testgroupId>
<version>1.0.0version>
<artifactId>bomartifactId>
parent>
<groupId>com.testgroupId>
<artifactId>parentartifactId>
<version>1.0.0version>
<packaging>pompackaging>
<dependencyManagement>
<dependencies>
<dependency>
<groupId>log4jgroupId>
<artifactId>log4jartifactId>
<version>1.2.12version>
dependency>
<dependency>
<groupId>commons-logginggroupId>
<artifactId>commons-loggingartifactId>
<version>1.1.1version>
dependency>
dependencies>
dependencyManagement>
<modules>
<module>project1module>
<module>project2module>
modules>
project>
这是具体的依赖集合,我们可以将几乎每个项目都有的依赖放在一起。
<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.0modelVersion>
<parent>
<groupId>com.testgroupId>
<version>1.0.0version>
<artifactId>parentartifactId>
parent>
<groupId>com.testgroupId>
<artifactId>project1artifactId>
<version>${project1Version}version>
<packaging>jarpackaging>
<dependencies>
<dependency>
<groupId>log4jgroupId>
<artifactId>log4jartifactId>
dependency>
dependencies>
project>
<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.0modelVersion>
<parent>
<groupId>com.testgroupId>
<version>1.0.0version>
<artifactId>parentartifactId>
parent>
<groupId>com.testgroupId>
<artifactId>project2artifactId>
<version>${project2Version}version>
<packaging>jarpackaging>
<dependencies>
<dependency>
<groupId>commons-logginggroupId>
<artifactId>commons-loggingartifactId>
dependency>
dependencies>
project>
在上述项目的根目录运行:mvn install 安装到自己的本地仓库。
在你的其它的独立项目中,将上述的parent作为项目的parent,被parent中管理的依赖便不需要写版本了。也可以在dependencies中添加第三步的依赖集合,简化你项目的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.0modelVersion>
<groupId>com.testgroupId>
<artifactId>useartifactId>
<version>1.0.0version>
<packaging>jarpackaging>
<parent>
<groupId>com.testgroupId>
<artifactId>parentartifactId>
<version>1.0.0version>
parent>
<dependencies>
<dependency>
<groupId>com.testgroupId>
<artifactId>project1artifactId>
dependency>
<dependency>
<groupId>com.testgroupId>
<artifactId>project2artifactId>
dependency>
dependencies>
project>
记住:在任何情况下,都可以使用dependencyManagement替代parent,关于二者的区别请读者自己搜索。
我的GitHub:pom-starters(我实际项目中使用的,可以直接mvn install,作为参考)
Maven 官方文档,本文代码出自官方文档(查询很久没有我想要的内容,结果偶然在官方文档找到了
Spring-Boot-Parent 项目地址,可以对比研究
Maven实战(三)——多模块项目的POM重构(这篇文章给了我启发,但是他的讲解还是不够详细,不能完全匹配我的问题