既然是要实践Spring Cloud Alibaba,那么简单的划分出几个微服务模块是必须的,以下用来测试实践Spring Cloud Alibaba的几个模块如下:
mall-common:公共模块,主要放些服务间共用的实体类,公共的工具类等。
mall-user:用户微服务,分配端口为10000~10009,方便之后多实例测试。
mall-product:商品微服务,分配端口为10010~10019,方便之后多实例测试。
mall-order:订单微服务,分配端口为10020~10029,方便之后多实例测试。
所以要先创建一个maven工程,删除src等文件夹,然后在pom.xml文件中做模块的整合,如下:
<?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>com.example</groupId>
<artifactId>demo</artifactId>
<version>0.0.1-SNAPSHOT</version>
<name>mall</name>
<description>商城</description>
<packaging>pom</packaging>
<!--聚合的模块-->
<modules>
<module>mall-common</module>
<module>mall-order</module>
<module>mall-product</module>
<module>mall-user</module>
</modules>
</project>
接着创建公共模块mall-common,要注意要在父工程下选择新建模块,直接走Spring Boot的创建模式就好了,然后其中pom.xml文件中依赖如下:
<?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">
<parent>
<artifactId>demo</artifactId>
<groupId>com.example</groupId>
<version>0.0.1-SNAPSHOT</version>
</parent>
<modelVersion>4.0.0</modelVersion>
<artifactId>mall-common</artifactId>
<description>微服务的公共包,包括依赖,工具类等</description>
<properties>
<java.version>1.8</java.version>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
<spring-cloud.version>Greenwich.SR3</spring-cloud.version>
<spring-cloud-alibaba.version>2.1.0.RELEASE</spring-cloud-alibaba.version>
</properties>
<dependencies>
<!--mybatis-plus依赖-->
<dependency>
<groupId>com.baomidou</groupId>
<artifactId>mybatis-plus-boot-starter</artifactId>
<version>3.3.2</version>
</dependency>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>8.0.20</version>
</dependency>
</dependencies>
<dependencyManagement>
<dependencies>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-dependencies</artifactId>
<version>${spring-cloud.version}</version>
<type>pom</type>
<scope>import</scope>
</dependency>
<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>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
</project>
然后把几个用来做测试的微服务项目初步构建起来,目前来说步骤都是一样,还是直接走Spring Boot的创建模式,有所不同的是每个微服务项目中的pom.xml文件要加上mall-common的依赖,如下:
最后形成如下结构:
接下来就是构建测试类和测试方法以及测试库了。