Maven 多项目依赖版本管理(Maven Multi Project version management)

博主工作负责的微服务已经达到了十几个,每个微服务相互直接都是独立的,有独立的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的方式构建自己的依赖管理。

创建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>

创建pom parent

创建一个子模块,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重构(这篇文章给了我启发,但是他的讲解还是不够详细,不能完全匹配我的问题

Maven 多项目依赖版本管理(Maven Multi Project version management)_第1张图片

你可能感兴趣的:(maven,java)