2023-02-27
原文作者:Java日知录 原文地址:https://javadaily.cn

本篇作为SpringCloud Alibaba微服务实战系列的第四篇,我们对之前的微服务框架进行优化,通过Maven bom机制管理所有组件的版本。

202302272258460022.png

BOM 简介

BOM(Bill of Materials)是由Maven提供的功能,它通过定义一整套相互兼容的jar包版本集合,使用时只需要依赖该BOM文件,即可放心的使用需要的依赖jar包,且无需再指定版本号。BOM的维护方负责版本升级,并保证BOM中定义的jar包版本之间的兼容性。

为什么要使用BOM

使用BOM除了可以方便使用者在声明依赖的客户端时不需要指定版本号外,最主要的原因是可以解决依赖冲突,防止你项目中出现NoSuchMethodError, ClassNotFoundException等不可控的异常。

项目改造

在SpringCloud项目体系中我们约定跟SpringCloud版本相关的用主pom文件进行版本控制,对于第三方组件或者公共模块的版本使用自定义的bom进行控制,接下来我们一步步对原有框架进行改造。

  • 建立cloud-bom模块 此模块很简单,只有一个pom文件,定义项目模块中所需要依赖的第三方组件和公共模块,完整的pom文件如下:
    <?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">
        <modelVersion>4.0.0</modelVersion>
        <groupId>com.jianzh5.cloud</groupId>
        <artifactId>cloud-bom</artifactId>
        <packaging>pom</packaging>
        <version>1.0.0</version>
    
        <properties>
            <mybatis-plus.version>3.1.1</mybatis-plus.version>
            <mysql.version>5.1.47</mysql.version>
            <cloud-alibaba.version>1.0.0</cloud-alibaba.version>
        </properties>
        <!--管理所有第三方jar包版本,SpringCloud Alibaba 版本由主Pom控制-->
        <dependencyManagement>
            <dependencies>
                <!--cloud-common 版本-->
                <dependency>
                    <groupId>com.jianzh5.cloud</groupId>
                    <artifactId>cloud-common</artifactId>
                    <version>${cloud-alibaba.version}</version>
                </dependency>
                <dependency>
                    <groupId>com.jianzh5.cloud</groupId>
                    <artifactId>account-feign</artifactId>
                    <version>${cloud-alibaba.version}</version>
                </dependency>
                <dependency>
                    <groupId>com.jianzh5.cloud</groupId>
                    <artifactId>product-feign</artifactId>
                    <version>${cloud-alibaba.version}</version>
                </dependency>
    
                <!--database-->
                <dependency>
                    <groupId>mysql</groupId>
                    <artifactId>mysql-connector-java</artifactId>
                    <version>${mysql.version}</version>
                </dependency>
                <dependency>
                    <groupId>com.baomidou</groupId>
                    <artifactId>mybatis-plus-boot-starter</artifactId>
                    <version>${mybatis-plus.version}</version>
                </dependency>
            </dependencies>
    
        </dependencyManagement>
    
        <repositories>
            <repository>
                <id>nexus-aliyun</id>
                <name>Nexus aliyun</name>
                <url>http://maven.aliyun.com/nexus/content/groups/public</url>
            </repository>
        </repositories>
    </project>

注意,这个模块不要再定义 依赖了,否则在主pom文件中引入bom后项目启动会报循环依赖的异常(死循环) ,具体错误如下所示:

    The build could not read 1 project -> [Help 1]
      
      The project com.jianzh5.cloud:cloud-aliaba:1.0.0 (D:\project_jianzh5\cloud-aliaba\pom.xml) has 1 error
        The dependencies of type=pom and with scope=import form a cycle: com.jianzh5.cloud:cloud-bom:1.0.0 -> com.jianzh5.cloud:cloud-bom:1.0.0 @ com.jianzh5.cloud:cloud-bom:1.0.0
    To see the full stack trace of the errors, re-run Maven with the -e switch.
    Re-run Maven using the -X switch to enable full debug logging.
    For more information about the errors and possible solutions, please read the following articles:
  • 在主pom文件中引入bom模块的pom
     <!--统一版本-->
    <dependency>
    	<groupId>com.jianzh5.cloud</groupId>
    	<artifactId>cloud-bom</artifactId>
    	<version>1.0.0</version>
    	<type>pom</type>
    	<scope>import</scope>
    </dependency>

此段内容需要放在dependencyManagement中第一个位置

  • 去掉其他模块中引用组件的<version>定义,如:
    <dependency>
    	<groupId>com.jianzh5.cloud</groupId>
    	<artifactId>cloud-common</artifactId>
    </dependency>
  • 改造完成后整体结构如下

    202302272258467903.png

  • 改造完成后对原项目进行测试,保证不影响原有功能 建议在项目初期就引入bom进行管理,后期改造会相对麻烦。

至此我们已经完成了项目的统一版本管理,那么本期的“SpringCloud Alibaba微服务实战四 - 版本管理”篇也就该结束啦,咱们下期有缘再见!

阅读全文