微服务maven公共版本、私服、依赖管理

前言

关于微服务的公共依赖模块的抽取、统一版本管理、统一私服配置等,尝试了多种方案,整理优化了多次,分享一下。

期望达到的效果:

1、统一的三方库版本管理

2、统一的私服配置(上传、下载、下载插件)

3、springcloud springalibaba springboot 版本依赖管理统一配置

正文

单独建一个common的maven工程,内部生成一个core module。

核心就两块,一块是最外层的 common-parent(pom artifacId的名字),一块是内层的common

关系图

image-20210423091353364

common工程

common的功能:
  • 公共类、公共工具类
  • 公共三方依赖
  • 注意:common的packaging是jar
common-parent的功能:
  • 版本的统一管理
  • springboot springcloud springalibaba 版本管理
  • 私服的配置
  • 注意:common-parent的packaging是pom
外层的pom.xml
image-20210423093343989


    4.0.0

    
        org.springframework.boot
        spring-boot-starter-parent
        2.2.8.RELEASE
    

    com.xiaoxi
    common-parent
    1.0-SNAPSHOT
    common-parent
    pom

    core

    
    
        3.4.0
        3.3.2
        3.8.7
        8.0.13
        2.0.7
        1.18.12
        5.3.8
        1.8
        1.4.0
        2.2.1.RELEASE


        1.8
        1.8
        Hoxton.SR6
        2.2.1.RELEASE
    


    
    
        
            
                org.springframework.cloud
                spring-cloud-dependencies
                pom
                ${spring-cloud.version}
                import
            
            
                com.alibaba.cloud
                spring-cloud-alibaba-dependencies
                ${spring-cloud-alibaba.version}
                pom
                import
            
            
                io.seata
                seata-spring-boot-starter
                ${seata.version}
            
            
                mysql
                mysql-connector-java
                ${mysql-connector.version}
            
        
    

    
    
        
            maven_xiaoxi
            http://192.168.148.237:8081/repository/maven-public/
            
                true
                always
            
            
                always
                true
            
        
    
    
    
        
            maven_xiaoxi
            http://192.168.148.237:8081/repository/maven-public/
            
                always
                true
            
            
                always
                true
            

        
    
    
    
        
            maven_xiaoxi
            http://192.168.148.237:8081/repository/maven-releases/
        
        
            maven_xiaoxi
            http://192.168.148.237:8081/repository/maven-snapshots/
        
    


内层core的pom.xml
image-20210423093126870


    
        common-parent
        com.xiaoxi
        1.0-SNAPSHOT
    

    4.0.0
    1.0-SNAPSHOT
    jar
    common


    
    
        
            mysql
            mysql-connector-java
            ${mysql-connector.version}
        

        
            org.springframework.boot
            spring-boot-starter-web
            2.2.8.RELEASE
        

        
            com.baomidou
            mybatis-plus-boot-starter
            ${mybatis-plus.version}
        

        
            com.baomidou
            dynamic-datasource-spring-boot-starter
            ${dynamic-datasource.version}
        

        
            p6spy
            p6spy
            ${p6sy.version}
        

        
            org.springframework.cloud
            spring-cloud-starter-openfeign
            2.2.3.RELEASE
        

        
            com.github.xiaoymin
            knife4j-spring-boot-starter
            ${knife4j.version}
        

        
            org.projectlombok
            lombok
            ${lombok.version}
        

        
            cn.hutool
            hutool-all
            ${hutool.version}
        

        
            com.alibaba.cloud
            spring-cloud-starter-alibaba-nacos-discovery
            
                
                    httpclient
                    org.apache.httpcomponents
                
            
            ${nacos.version}
        

        
        
            com.alibaba.cloud
            spring-cloud-alibaba-seata
            2.2.0.RELEASE
            
                
                    io.seata
                    seata-spring-boot-starter
                
            
        

        
            io.seata
            seata-spring-boot-starter
            ${seata.version}
        

        
            redis.clients
            jedis
        

        
            com.auth0
            java-jwt
            3.15.0
        

        
            com.alibaba.cloud
            spring-cloud-starter-alibaba-sentinel
        

    



发布

每次发布,最好先clean,然后在最外层maven deploy即可。(因为他们是父子级关系)

微服务

image-20210418160500541

xxxx-interface

image-20210418160710114



    
        com.xiaoxi
        common-parent
        1.0-SNAPSHOT
    
    com.example
    1.0-SNAPSHOT

    4.0.0

    test1-interface

    
        
            com.xiaoxi
            common
            1.0-SNAPSHOT
        
    


    
        
            maven_xiaoxi
            http://192.168.148.237:8081/repository/maven-public/
            
                true
                always
            
            
                always
                true
            
        
    


可以看到,这里interface,是继承了common-parent,因为它是在私服上面的,所以无论如何你也需要配置一个私服的拉取仓库。但是好处是,你继承了common-parent,等于里面的 下载、插件下载、发布的配置都有了,就不必再配置发布了。

xxxx-service

image-20210418160853622


    4.0.0
        
            com.xiaoxi
            common-parent
            1.0-SNAPSHOT
        

    com.example
    test1-service
    0.0.1-SNAPSHOT
    test1-service
    Demo project for Spring Boot


    

        
            org.springframework.boot
            spring-boot-starter-test
            test
        

        
            com.example
            test1-interface
            1.0-SNAPSHOT
        
    

    
    
        
            
            local
            
                local
                true
                
            
            
                true
            
        
        
            
            dev
            
                dev
                true
                http://192.168.148.236:2375
            
        
        
            
            test
            
                test
                false
                http://192.168.148.235:2375
            
        
        
            
            prod
            
                prod
                false
                http://xxxx:2375
            
        
    

    
    
        
        ${project.artifactId}

        
            
                org.springframework.boot
                spring-boot-maven-plugin
            

        

    

    
        
            maven_xiaoxi
            http://192.168.148.237:8081/repository/maven-public/
            
                true
                always
            
            
                always
                true
            
        
    


service,现在就清爽很多了。只需要继承common-parent,加上私服拉取,就可以节省很多配置了。依赖的话,只需要微服务模块间的 和 自己的 interface的依赖即可。

依赖关系为:

xxxx-service -> xxxx-interface -> common

继承关系为

xxx-interface -> common-parent

xxx-service -> common-parent

关于service想要自定义版本的实现

在整理优化的过程中发现一个问题,就是:

我们公共依赖里面配置的seata版本是1.4.0,而最终在service里面的版本是1.1.0。

这是为什么呢?这就跟maven的依赖加载顺序有关系了。

有一篇文章讲得不错,分享一下

这里也简述一下:

我们大致把依赖分为这几个级别:

  • 本级

自身的工程的直接依赖

  • 上级

自身工程的parent继承

  • 下级

依赖的库的依赖 自身工程依赖的三方库 的 依赖

  • 版本管理

自身工程的版本管理

优先级顺序为:

本级 > 本级版本管理 > 上级 > 上级版本管理 > 下级 (无下级版本管理)

而对照我们的公共依赖库的话:

我们parent继承的common-parent的版本优先级是高于 依赖的第三方common的依赖的版本的

也就是说,common里面是1.4.0,而parent里面是1.1.0(springalibaba),此时最终就会以1.1.0为最优先。

下面是图

image-20210423095204507

那么这种情况怎么办呢?

我们知道maven的依赖如果是有多个相同的,那么后面的会覆盖前面的配置。

在我们common-parent的dependencyManagement里面已经定义了 springalibaba,那么我们就可以在下面重新指定一下 seata的版本为1.4.0,这样对于common-parent而言最终其实seata版本就是1.4.0了。

image-20210423095706068

对照加载顺序就是

  • 原来:

本级(无) > 本级版本管理 (无) > 上级(无) > 上级版本管理 (common-parent 1.1.0)> 下级 (common 1.4.0) (无下级版本管理)

  • 现在:

本级(无) > 本级版本管理 (无) > 上级(无) > 上级版本管理 (common-parent 1.4.0)> 下级 (common 1.4.0)

关于作者

作者是一个热爱学习、开源、分享,传播正能量,喜欢打篮球、头发还很多的程序员-。-

热烈欢迎大家关注、点赞、评论交流!

:https://www.jianshu.com/u/d234d1569eed

github:https://github.com/fly7632785

CSDN:https://blog.csdn.net/fly7632785

掘金:https://juejin.im/user/5efd8d205188252e58582dc7/posts

你可能感兴趣的:(微服务maven公共版本、私服、依赖管理)