怎样简洁高效的搭建一个SpringCloud2023的maven工程

打印 上一主题 下一主题

主题 847|帖子 847|积分 2541

前言

依靠管理有gradle和maven,在这里选择比较常用和方便的Maven作为工程项目和依靠管理工具来搭建SpringCloud实战工程。主要用到的maven管理方式是多模块和bom依靠管理。
什么是maven的多模块依靠管理

Maven 多模块项目相对于单模块项目而言,依靠是不共享的,但父模块提供了全局共享依靠的功能,可以针对差别模块所需要依靠的包进行分模块引入。具体如下:

  • 所有子模块都依靠的包,如junit可以同一由父模块中的设置依靠。
  • 多个子模块但非全部子模块依靠的包,可以在父模块中的中同一管理依靠版本,再由每个子模块自主引入依靠,如许设置可以达到项目中多个子模块依靠的包版本同一的目的。
  • 单个子模块依靠的包,可以直接交由这个子模块引入即可。但偶然候出于对后续可能添加子模块思量,纵然当前只有一个子模块依靠的包,也可以同一交由父模块的同一管理,而如果确认后续不会再加子模块的,可以按前者进行处理。
在父模块中,可通过同一管理依靠包的版本,让共享包也更加同一管理。
什么是maven的bom依靠管理

Maven 的 BOM(Bill of Materials)依靠管理是一种用于集中管理项目依靠关系和版本的方式,它提供了一种方便的方法来确保多个项目或模块在使用雷同依靠时具有划一的版本。
BOM 通常是一个特殊的 Maven POM(Project Object Model)文件,其中定义了项目所需的依靠项及其版本。通过在其他项目中引用这个 BOM,这些项目将主动获取 BOM 中定义的依靠版本,而无需明确指定每个依靠的版本。
如许做的好处是可以减少重复的依靠设置工作,并确保在多个项目中使用雷同的依靠版本,从而减少由于依靠不划一导致的问题。此外,BOM 还可以用于管理依靠的升级和版本控制,只需在 BOM 中更新依靠的版本,所有引用该 BOM 的项目都会主动获取最新的版本。
要使用 Maven 的 BOM 依靠管理,通常需要实行以下步骤:

  • 创建或获取一个 BOM POM 文件,其中定义了项目的依靠和版本信息。
  • 在需要使用 BOM 的项目中,通过在部分引用 BOM POM 文件。
  • 在项目的具体依靠部分,可以直接使用 BOM 中定义的依靠,而无需明确指定版本。
组件选型

在“SpringCloud2023最新版本该怎样进行组件选型?”一文中已经具体的先容了SpringCloud的组件对比和选型,具体可以查看合集里面的相关文档。

  • 注册中央(Spring Cloud Zookeeper):负责服务的注册和发现。
  • 网关(Spring Cloud Gateway):作为外部请求的入口,实现路由和负载均衡。
  • 云服务设置(Spring Cloud Config):用于管理服务的设置信息。
  • 熔断(Sentinel):提供熔断器功能,实现服务的限流和降级。
  • 服务追踪(Micrometer Tracing):用于追踪和监控服务的性能和调用情况。
  • 测试集成(JUnit 5 + Spring Boot Test):用于编写和实行单元测试。
  • 远程调用(OpenFeign):用于服务之间的远程调用。
  • 接口文档(springdoc-openapi + openapi3):用于天生和管理 API 的文档。
  • 分布式事务(Seata):用于处理跨多个服务的事务。
版本选择

在“SpringCloud和SpringBoot的版本依靠该怎么选择”一文中已经具体的先容了SpringCloud的版本怎样选择,具体可以查看合集里面的相关文档。
组件版本jdk17spring boot3.2.xspring cloud2023.0.xspring cloud alibaba2022.0.0.0(还未更新,但是兼容2023)为什么选择JDK17

选择JDK17的原因如下:

  • JDK 17是 LTS(恒久支持版)。
  • JDK 17性能提升不少。
  • 大多数第三方框架和库都已经支持,不会有什么大坑。
  • JDK 17有更多的新特性支持。
Maven工程依靠阐明
  1. |-- banana-client1
  2. |-- banana-client2
  3. |-- banana-client3
  4. |-- banana-client4-sentinel
  5. |-- banana-client5-tracing
  6. |-- banana-client6-test
  7. |-- banana-common
  8. |   |-- banana-common-bom
  9. |   `-- banana-common-core
  10. |-- banana-config
  11. |-- banana-gateway
  12. |-- banana-gateway-sso
  13. `-- banana-seata-example
复制代码

  • 根目录下的pom.xml负责管理整个项目的版本和依靠引入版本管理,以及子模块的管理。
  • banana-common-bom 负责管理整个公共依靠的版本,好比undertow、swagger的版本。
  • banana-common-core 负责管理整个公共组件的引入,好比 hutool、validation、test等。
  • gateway 相关项目为SCG相关工程。
  • client 相关项目为springboot相关工程。
  • 其他工程会在后续的文章阐明。欢迎持续关注。
顶级工程pom.xml设置

该maven的pom文件定义了如下内容:

  • Maven 项目的模块列表
  • Maven 项目的属性列表
  • Maven 项目的依靠管理
  • Maven 项目的仓库列表
  • Maven 项目的构建设置
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <project xmlns="http://maven.apache.org/POM/4.0.0"
  3.          xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  4.          xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
  5.    
  6.     <modelVersion>4.0.0</modelVersion>
  7.    
  8.     <groupId>io.rainforest</groupId>
  9.    
  10.     <artifactId>banana</artifactId>
  11.    
  12.     <version>1.0</version>
  13.    
  14.     <packaging>pom</packaging>
  15.    
  16.     <modules>
  17.         <module>banana-gateway</module>
  18.         <module>banana-config</module>
  19.         <module>banana-common</module>
  20.         <module>banana-client1</module>
  21.         <module>banana-client2</module>
  22.         <module>banana-client3</module>
  23.         <module>banana-client4-sentinel</module>
  24.         <module>banana-client5-tracing</module>
  25.         <module>banana-client6-test</module>
  26.         <module>banana-seata-example</module>
  27.         <module>banana-gateway-sso</module>
  28.     </modules>
  29.    
  30.     <properties>
  31.         
  32.         <maven.compiler.source>17</maven.compiler.source>
  33.         
  34.         <maven.compiler.target>17</maven.compiler.target>
  35.         
  36.         <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
  37.         
  38.         <spring-boot.version>3.2.3</spring-boot.version>
  39.         
  40.         <spring-cloud.version>2023.0.0</spring-cloud.version>
  41.         
  42.         <spring-cloud-alibaba.version>2022.0.0.0</spring-cloud-alibaba.version>
  43.     </properties>
  44.    
  45.     <dependencyManagement>
  46.         
  47.         <dependencies>
  48.             
  49.             <dependency>
  50.                 <groupId>io.rainforest</groupId>
  51.                 <artifactId>banana-common-bom</artifactId>
  52.                 <version>${project.version}</version>
  53.                 <type>pom</type>
  54.                 <scope>import</scope>
  55.             </dependency>
  56.             
  57.             <dependency>
  58.                 <groupId>org.springframework.boot</groupId>
  59.                 <artifactId>spring-boot-dependencies</artifactId>
  60.                 <version>${spring-boot.version}</version>
  61.                 <type>pom</type>
  62.                 <scope>import</scope>
  63.             </dependency>
  64.             
  65.             <dependency>
  66.                 <groupId>org.springframework.cloud</groupId>
  67.                 <artifactId>spring-cloud-dependencies</artifactId>
  68.                 <version>${spring-cloud.version}</version>
  69.                 <type>pom</type>
  70.                 <scope>import</scope>
  71.             </dependency>
  72.             
  73.             <dependency>
  74.                 <groupId>com.alibaba.cloud</groupId>
  75.                 <artifactId>spring-cloud-alibaba-dependencies</artifactId>
  76.                 <version>${spring-cloud-alibaba.version}</version>
  77.                 <type>pom</type>
  78.                 <scope>import</scope>
  79.             </dependency>
  80.         </dependencies>
  81.     </dependencyManagement>
  82.    
  83.     <repositories>
  84.         
  85.         <repository>
  86.             <id>central</id>
  87.             <name>Central Repository</name>
  88.             <url>https://mirrors.huaweicloud.com/repository/maven/</url>
  89.             <layout>default</layout>
  90.             <snapshots>
  91.                 <enabled>false</enabled>
  92.             </snapshots>
  93.         </repository>
  94.     </repositories>
  95.    
  96.     <build>
  97.         
  98.         <finalName>${project.name}</finalName>
  99.         
  100.         <resources>
  101.             
  102.             <resource>
  103.                 <directory>src/main/resources</directory>
  104.                
  105.                 <filtering>true</filtering>
  106.             </resource>
  107.         </resources>
  108.         
  109.         <pluginManagement>
  110.             
  111.             <plugins>
  112.                
  113.                 <plugin>
  114.                     <groupId>org.springframework.boot</groupId>
  115.                     <artifactId>spring-boot-maven-plugin</artifactId>
  116.                     <version>${spring-boot.version}</version>
  117.                     <configuration>
  118.                         
  119.                         <finalName>${project.build.finalName}</finalName>
  120.                         
  121.                         <layers>
  122.                             <enabled>true</enabled>
  123.                         </layers>
  124.                     </configuration>
  125.                     
  126.                     <executions>
  127.                         
  128.                         <execution>
  129.                             <goals>
  130.                                 <goal>repackage</goal>
  131.                             </goals>
  132.                         </execution>
  133.                     </executions>
  134.                 </plugin>
  135.             </plugins>
  136.         </pluginManagement>
  137.     </build>
  138. </project>
复制代码
工程的公用依靠bom设置

该maven的pom文件定义了如下内容:

  • Maven 项目的属性列表,包含版本等信息
  • Maven 项目使用到的依靠版本管理
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <project xmlns="http://maven.apache.org/POM/4.0.0"
  3.          xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  4.          xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
  5.     <groupId>io.rainforest</groupId>
  6.     <artifactId>banana-common-bom</artifactId>
  7.     <version>1.0</version>
  8.     <modelVersion>4.0.0</modelVersion>
  9.     <packaging>pom</packaging>
  10.     <description>banana-common-bom 公共依赖管理</description>
  11.     <properties>
  12.         <banana.common.version>${project.version}</banana.common.version>
  13.         <spring-boot.version>3.1.3</spring-boot.version>
  14.         <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
  15.         <log4j2.version>2.17.1</log4j2.version>
  16.         <maven.compiler.target>17</maven.compiler.target>
  17.         <maven.compiler.source>17</maven.compiler.source>
  18.         <git.commit.plugin>4.9.9</git.commit.plugin>
  19.         <spring.checkstyle.plugin>0.0.39</spring.checkstyle.plugin>
  20.         <fastjson.version>1.2.83</fastjson.version>
  21.         <springdoc.version>2.1.0</springdoc.version>
  22.         <swagger.core.version>2.2.14</swagger.core.version>
  23.         <mybatis-plus.version>3.5.3.2</mybatis-plus.version>
  24.         <mysql.version>8.0.33</mysql.version>
  25.         <dynamic-ds.version>4.1.3</dynamic-ds.version>
  26.         <seata.version>1.6.1</seata.version>
  27.         <excel.version>3.1.0</excel.version>
  28.         <asm.version>7.1</asm.version>
  29.         <sms.version>3.0.0</sms.version>
  30.         <jaxb.version>2.3.5</jaxb.version>
  31.         <shardingsphere.version>5.4.0</shardingsphere.version>
  32.         <hutool.version>5.8.21</hutool.version>
  33.         <mica.version>3.0.8</mica.version>
  34.         <sentinel.version>1.8.4</sentinel.version>
  35.     </properties>
  36.    
  37.     <dependencyManagement>
  38.         <dependencies>
  39.             <dependency>
  40.                 <groupId>io.rainforest</groupId>
  41.                 <artifactId>banana-common-core</artifactId>
  42.                 <version>${banana.common.version}</version>
  43.             </dependency>
  44.             <dependency>
  45.                 <groupId>com.mysql</groupId>
  46.                 <artifactId>mysql-connector-j</artifactId>
  47.                 <version>${mysql.version}</version>
  48.             </dependency>
  49.             
  50.             <dependency>
  51.                 <groupId>org.springdoc</groupId>
  52.                 <artifactId>springdoc-openapi-starter-webflux-ui</artifactId>
  53.                 <version>${springdoc.version}</version>
  54.             </dependency>
  55.             <dependency>
  56.                 <groupId>org.springdoc</groupId>
  57.                 <artifactId>springdoc-openapi-starter-webmvc-api</artifactId>
  58.                 <version>${springdoc.version}</version>
  59.             </dependency>
  60.             <dependency>
  61.                 <groupId>io.swagger.core.v3</groupId>
  62.                 <artifactId>swagger-annotations-jakarta</artifactId>
  63.                 <version>${swagger.core.version}</version>
  64.             </dependency>
  65.             
  66.             <dependency>
  67.                 <groupId>com.alibaba</groupId>
  68.                 <artifactId>fastjson</artifactId>
  69.                 <version>${fastjson.version}</version>
  70.             </dependency>
  71.             
  72.             <dependency>
  73.                 <groupId>com.baomidou</groupId>
  74.                 <artifactId>dynamic-datasource-spring-boot3-starter</artifactId>
  75.                 <version>${dynamic-ds.version}</version>
  76.             </dependency>
  77.             
  78.             <dependency>
  79.                 <groupId>io.springboot.sms</groupId>
  80.                 <artifactId>aliyun-sms-spring-boot-starter</artifactId>
  81.                 <version>${sms.version}</version>
  82.             </dependency>
  83.             
  84.             <dependency>
  85.                 <groupId>io.seata</groupId>
  86.                 <artifactId>seata-serializer-kryo</artifactId>
  87.                 <version>${seata.version}</version>
  88.             </dependency>
  89.             
  90.             <dependency>
  91.                 <groupId>com.baomidou</groupId>
  92.                 <artifactId>mybatis-plus-boot-starter</artifactId>
  93.                 <version>${mybatis-plus.version}</version>
  94.             </dependency>
  95.             <dependency>
  96.                 <groupId>com.baomidou</groupId>
  97.                 <artifactId>mybatis-plus-extension</artifactId>
  98.                 <version>${mybatis-plus.version}</version>
  99.             </dependency>
  100.             <dependency>
  101.                 <groupId>com.baomidou</groupId>
  102.                 <artifactId>mybatis-plus-annotation</artifactId>
  103.                 <version>${mybatis-plus.version}</version>
  104.             </dependency>
  105.             
  106.             <dependency>
  107.                 <groupId>cn.hutool</groupId>
  108.                 <artifactId>hutool-bom</artifactId>
  109.                 <version>${hutool.version}</version>
  110.                 <type>pom</type>
  111.                 <scope>import</scope>
  112.             </dependency>
  113.             
  114.             <dependency>
  115.                 <groupId>net.dreamlu</groupId>
  116.                 <artifactId>mica-bom</artifactId>
  117.                 <version>${mica.version}</version>
  118.                 <type>pom</type>
  119.                 <scope>import</scope>
  120.             </dependency>
  121.             
  122.             <dependency>
  123.                 <groupId>org.springframework.boot</groupId>
  124.                 <artifactId>spring-boot-starter-web</artifactId>
  125.                 <version>${spring-boot.version}</version>
  126.                 <exclusions>
  127.                     
  128.                     <exclusion>
  129.                         <artifactId>spring-boot-starter-tomcat</artifactId>
  130.                         <groupId>org.springframework.boot</groupId>
  131.                     </exclusion>
  132.                 </exclusions>
  133.             </dependency>
  134.             <dependency>
  135.                 <groupId>com.github.xiaoymin</groupId>
  136.                 <artifactId>knife4j-openapi3-jakarta-spring-boot-starter</artifactId>
  137.                 <version>4.3.0</version>
  138.             </dependency>
  139.         </dependencies>
  140.     </dependencyManagement>
  141.     <build>
  142.         <plugins>
  143.             
  144.             <plugin>
  145.                 <groupId>io.github.git-commit-id</groupId>
  146.                 <artifactId>git-commit-id-maven-plugin</artifactId>
  147.                 <version>${git.commit.plugin}</version>
  148.             </plugin>
  149.             
  150.             <plugin>
  151.                 <groupId>io.spring.javaformat</groupId>
  152.                 <artifactId>spring-javaformat-maven-plugin</artifactId>
  153.                 <version>${spring.checkstyle.plugin}</version>
  154.             </plugin>
  155.         </plugins>
  156.     </build>
  157. </project>
复制代码
源码信息

和“SpringCloud实战”对应的源码信息如下:
关于作者

来自一线全栈程序员nine的八年探索与实践,持续迭代中。欢迎关注“雨林寻北”或添加个人卫星codetrend(备注技术)。

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

徐锦洪

金牌会员
这个人很懒什么都没写!

标签云

快速回复 返回顶部 返回列表