前言
关于微服务的公共依赖模块的抽取、统一版本管理、统一私服配置等,尝试了多种方案,整理优化了多次,分享一下。
期望达到的效果:
1、统一的三方库版本管理
2、统一的私服配置(上传、下载、下载插件)
3、springcloud springalibaba springboot 版本依赖管理统一配置
正文
单独建一个common的maven工程,内部生成一个core module。
核心就两块,一块是最外层的 common-parent(pom artifacId的名字),一块是内层的common
关系图
common工程
common的功能:
- 公共类、公共工具类
- 公共三方依赖
- 注意:common的packaging是jar
common-parent的功能:
- 版本的统一管理
- springboot springcloud springalibaba 版本管理
- 私服的配置
- 注意:common-parent的packaging是pom
外层的pom.xml
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
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即可。(因为他们是父子级关系)
微服务
xxxx-interface
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
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继承的common-parent的版本优先级是高于 依赖的第三方common的依赖的版本的
也就是说,common里面是1.4.0,而parent里面是1.1.0(springalibaba),此时最终就会以1.1.0为最优先。
下面是图
那么这种情况怎么办呢?
我们知道maven的依赖如果是有多个相同的,那么后面的会覆盖前面的配置。
在我们common-parent的dependencyManagement里面已经定义了 springalibaba,那么我们就可以在下面重新指定一下 seata的版本为1.4.0,这样对于common-parent而言最终其实seata版本就是1.4.0了。
对照加载顺序就是:
- 原来:
本级(无) > 本级版本管理 (无) > 上级(无) > 上级版本管理 (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