微服务架构及解决方案
构建SpringCloud聚合项目并进行初始化
工程结构
聚合工程结构设计,例如:
GitCGB2105IVProjects (工作区/空项目)
├── 01-sca //(微服务父工程)
├── sca-provider //服务提供方法
├── sca-consumer //服务消费方法
├── sca-gateway //网关服务
创建工程空项目
项目初始化配置
1.配置maven环境(尽量一个项目一个本地仓库,可能会有依赖冲突)
2.配置JDK编译环境
3.配置项目的编码方式
### 创建聚合父类工程
1.创建父工程模块
2.添加核心依赖及版本的管理
<?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 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<!--
<parent>
<artifactId>spring-boot-starter-parent</artifactId>
<groupId>org.springframework.boot</groupId>
<version>2.3.2.RELEASE</version>
</parent>
-->
<groupId>com.cy</groupId>
<artifactId>01-sca</artifactId>
<!--创建父工程的子工程时,父工程的打包方式会自动变为pom方式-->
<packaging>pom</packaging>
<version>1.0-SNAPSHOT</version>
<!--创建子工程时会自动将子工程的名字放到modules-->
<modules>
<module>sca-provider</module>
<module>sca-consumer</module>
<module>sca-gateway</module>
<module>sca-basic</module>
</modules>
<!--properties中定义一些属性元素-->
<properties>
<spring.boot.version>2.3.2.RELEASE</spring.boot.version>
</properties>
<!--maven的父工程为一个pom工程,
此工程主要负责依赖版本及部分基础依赖的管理-->
<dependencyManagement>
<dependencies>
<!--Spring Boot 依赖(此依赖中定义了springboot工程核心依赖的版本)-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-dependencies</artifactId>
<version>${spring.boot.version}</version>
<scope>import</scope>
<type>pom</type> <!--只有类型为pom的才可以import-->
</dependency>
<!--Spring Cloud 依赖-->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-dependencies</artifactId>
<version>Hoxton.SR9</version>
<scope>import</scope>
<type>pom</type>
</dependency>
<!--Spring Cloud Alibaba依赖-->
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-alibaba-dependencies</artifactId>
<version>2.2.6.RELEASE</version>
<scope>import</scope>
<type>pom</type>
</dependency>
</dependencies>
</dependencyManagement>
<!--dependencies元素中定义子工程中都需要的依赖-->
<dependencies>
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<!--provided表示只在编译阶段有效运行阶段无效-->
<scope>provided</scope>
</dependency>
</dependencies>
<build>
<plugins>
<!--修改maven编译版本-->
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<version>3.8.1</version>
<configuration>
<source>8</source>
<target>8</target>
</configuration>
</plugin>
</plugins>
</build>
</project>
依赖版本参考
https://github.com/alibaba/spring-cloud-alibaba/wiki/%E7%89%88%E6%9C%AC%E8%AF%B4%E6%98%8E
创建服务提供方模块
创建服务消费方模块
创建网管服务模块
总结
微服务是一个架构设计方式,此架构中的每一个服务(service)都是针对一组功能而设计的,并专注解决特定的问题,如果开发人员逐渐将更多代码增加到一项服务中并且这项服务变得复杂,那么可以将其拆分成多项更小的服务。接下来进行独立的开发、测试、部署、运行、维护。进而更好,更灵活的处理客户端的请求并提高系统的可靠性,可扩展性。