# 从0搭建Java分布式系统 - 01 - 创建项目

182 阅读1分钟

技术栈

  • 分布式框架: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的对应关系: image.png

Spring Boot 2.4以下版本 和 Spring Cloud Alibaba的对应关系: image.png

关于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>