技术栈
- 分布式框架:Spring Cloud Alibaba + Springboot
- 注册中心:Nacos
- 配置中心:Nacos
- 分布式事务:Seate
- 缓存:Redis
- 异步消息:RabbitMQ
- 数据库:MySQL 5.7
- 网关:Spring Cloud Gateway
- JDK:1.8
1. 选取Spring Cloud Alibaba 版本和 Springboot版本
打开Spring Cloud Alibaba官方文档,找到版本说明: github.com/alibaba/spr…
Spring Boot 2.4+版本 和 Spring Cloud Alibaba的对应关系:
Spring Boot 2.4以下版本 和 Spring Cloud Alibaba的对应关系:
关于SpringBoot的版本选取:
- SpringBoot 3.0以上的版本,不再支持JDK8了,必须搭配更高版本的JDK。那日常学习,肯定不能选3.0以上的。因为JDK8之后的都收费。所以SpringBoot要选3.0以下的。
- 根据Spring Cloud Alibaba文档说明,SpringBoot2.4+之后的版本变化比较大。而很多项目都是在2-3年前开发的,多半用是SpringBoot2.4以下的版本。所以,日常学习选取SpringBoot2.4以下的版本比较合适,学的内容和工作的用到的技术相匹配,可以提高工作效率。
最终确定选取的版本
- Spring Boot: 2.2.5.RELEASE
- Spring Cloud Alibaba :2.2.1.RELEASE
- Spring Cloud: Hoxton.SR3
2. 使用Idea创建项目。添加pom文件。
要做的工作如下:
- 引入springboot依赖管理
- 引入Spring Cloud Alibaba依赖管理
最终代码: github.com/AllenDengMs…
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 https://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>org.backend.cloud</groupId>
<artifactId>spirng-cloud-project-parent</artifactId>
<version>1.0.0-SNAPSHOT</version>
<packaging>pom</packaging>
<properties>
<!-- jdk -->
<java.version>1.8</java.version>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
<maven.compiler.source>8</maven.compiler.source>
<maven.compiler.target>8</maven.compiler.target>
<!--
Spring框架相关版本,怎么选择版本,请看:
https://github.com/alibaba/spring-cloud-alibaba/wiki/%E7%89%88%E6%9C%AC%E8%AF%B4%E6%98%8E
-->
<spring-boot.version>2.2.5.RELEASE</spring-boot.version>
<spring-cloud.version>Hoxton.SR3</spring-cloud.version>
<spring-cloud-alibaba.version>2.2.1.RELEASE</spring-cloud-alibaba.version>
</properties>
<dependencyManagement>
<dependencies>
<!--
SpringBoot 依赖
引入 spirngboot-dependencies pom 是为了管理java包。代替了直接继承parent:
<parent>...<artifactId>spring-boot-starter-parent</artifactId>...<parent>
-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-dependencies</artifactId>
<version>${spring-boot.version}</version>
<type>pom</type>
<scope>import</scope>
</dependency>
<!--
引入 spring-cloud-dependencies来管理版本
因为以后会用到spring-cloud-gateway,这些属于spring-cloud生态圈的中间件
-->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-dependencies</artifactId>
<version>${spring-cloud.version}</version>
<type>pom</type>
<scope>import</scope>
</dependency>
<!-- spring-cloud-alibaba-dependencies -->
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-alibaba-dependencies</artifactId>
<version>${spring-cloud-alibaba.version}</version>
<type>pom</type>
<scope>import</scope>
</dependency>
</dependencies>
</dependencyManagement>
<dependencies>
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
<configuration>
<excludes>
<exclude>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
</exclude>
</excludes>
</configuration>
</plugin>
</plugins>
</build>
<!--maven repositories-->
<repositories>
<repository>
<id>public</id>
<name>aliyun nexus</name>
<url>https://maven.aliyun.com/repository/public</url>
<releases>
<enabled>true</enabled>
</releases>
</repository>
</repositories>
<pluginRepositories>
<pluginRepository>
<id>public</id>
<name>aliyun nexus</name>
<url>https://maven.aliyun.com/repository/public</url>
<releases>
<enabled>true</enabled>
</releases>
<snapshots>
<enabled>false</enabled>
</snapshots>
</pluginRepository>
</pluginRepositories>
</project>