SpringCloud01-简介
1.微服务是什么?
- 微服务就是将单一应用程序划分成一组小的服务,每个服务运行在独立的进程内,服务直接相互协调,相互配置,最终为用户提供统一的服务。
- 服务之间采用轻量级的通信机制相互沟通,每个服务围绕具体的业务进行构建,并且能够被独立部署到生成环境中。
- 微服务的优点:每个微服务单一职责,高内聚,低耦合;容易和第三方集成,使得微服务可以集成自动部署,如Jenkins......
- 在构建微服务时需要考虑的问题。
- 服务之间如何通信问题。解决方案:RestTemplate+Ribbon 或者 OpenFeign。
- 服务之间的调度,如何避免扇出、雪崩等问题?解决方案:Hystrix 或者 Sentinel。
- 如何维护服务提供者的统一状态?解决方案:使用注册中心,如Eureka、Zookeeper、Consul、Nacos......
- 网关。Zuul 和 Gateway。
- 关于微服务的文章。http://www.bdata-cap.com/newsinfo/1713874.html。
2.SpringCloud是什么?
- SpringCloud是一个全局的服务器治理框架,是分布式微服务架构一站式解决方案,是多种微服务架构落地的技术的集合体。
- SpringCloud借助Springboot可以快速的构建起一个又一个的微服务。
- SpringCloud官网文档地址。https://docs.spring.io/spring-cloud/docs/2020.0.3/reference/htmlsingle/。
- 查看SpringCloud和Springboot版本的对应关系。https://start.spring.io/actuator/info。
- SpringCloud源码地址。https://github.com/spring-cloud。
- SpringCloud官网架构图。

3.SpringCloud组件说明
- 注册中心。Eukeka(停止维护)、Zookeeper、Consul、Nacos(推荐使用)。
- 服务调用1。Ribbon(停止维护)、LoadBalancer(出自Spring社区)。
- 服务调用2。Feign(停止维护)、OpenFeign(Spring社区,推荐使用)。
- 服务降级。Hystrix(停止维护)、Resilience4j(国外推荐使用)、Sentinel(国内推荐使用)。
- 服务网关。Zuul(不推荐)、Zuul2、Gateway(Spring社区,推荐使用)。
- 服务配置。Config(停止维护)、Apolo(阿波罗)、Nacos(推荐使用)。
- 服务总线。Bus(停止维护)、Nacos(推荐使用)。
4.父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 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>com.my.springcloud</groupId>
<artifactId>cloud202109</artifactId>
<version>1.0-SNAPSHOT</version>
<modules>
<module>cloud-provider-payment8001</module>
<module>cloud-consumer-order80</module>
<module>cloud-api-commons</module>
<module>cloud-eureka-server7001</module>
<module>cloud-eureka-provider-payment8001</module>
<module>cloud-eureka-consumer-order80</module>
<module>cloud-eureka-server7002</module>
<module>cloud-eureka-provider-payment8002</module>
<module>cloud-zookeeper-provider-payment8004</module>
<module>cloud-zookeeper-consumer-order80</module>
<module>cloud-consul-provider-payment8006</module>
<module>cloud-consul-consumer-order80</module>
<module>cloud-eureka-consumer-open-feign-order80</module>
<module>cloud-eureka-consumer-ribbon-order80</module>
<module>cloud-eureka-hystrix-provider-payment8001</module>
<module>cloud-eureka-hystrix-open-feign-consumer-order80</module>
<module>cloud-consumer-hystrix-dashboard9001</module>
<module>cloud-gateway-gateway9527</module>
<module>cloud-config-center-3344</module>
<module>cloud-config-client-3355</module>
<module>cloud-config-client-3366</module>
<module>cloud-stream-rabbitmq-provider8801</module>
<module>cloud-stream-rabbitmq-consumer8802</module>
<module>cloud-stream-rabbitmq-consumer8803</module>
<module>cloud-euerka-sleuth-zipkin-provider-payment8001</module>
<module>cloud-euerka-sleuth-zipkin-consumer80</module>
<module>cloud-nacos-provider-payment9001</module>
<module>cloud-nacos-provider-payment9002</module>
<module>cloud-nacos-consumer-order83</module>
<module>cloud-nacos-config-client3377</module>
<module>cloud-nacos-sentinel-service8401</module>
<module>cloud-nacos-provider-payment9003</module>
<module>cloud-nacos-provider-payment9004</module>
<module>cloud-nacos-consumer-order84</module>
<module>cloud-nacos-seata-order-service2001</module>
<module>cloud-nacos-seata-storage-service2002</module>
<module>cloud-nacos-seata-account-service2003</module>
</modules>
<packaging>pom</packaging>
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<maven.compiler.source>1.8</maven.compiler.source>
<maven.compiler.target>1.8</maven.compiler.target>
<junit.version>4.13.2</junit.version>
<log4j.version>1.2.17</log4j.version>
<lombok.version>1.18.20</lombok.version>
<mysql.version>8.0.26</mysql.version>
<druid.version>1.2.6</druid.version>
<mybatis.spring.boot.version>2.2.0</mybatis.spring.boot.version>
</properties>
<dependencyManagement>
<dependencies>
<!--spring boot 2.5.4-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-dependencies</artifactId>
<version>2.5.4</version>
<type>pom</type>
<scope>import</scope>
</dependency>
<!--spring cloud 2020.0.3-->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-dependencies</artifactId>
<version>2020.0.3</version>
<type>pom</type>
<scope>import</scope>
</dependency>
<!--spring cloud alibaba 2021.1-->
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-alibaba-dependencies</artifactId>
<version>2021.1</version>
<type>pom</type>
<scope>import</scope>
</dependency>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>${mysql.version}</version>
</dependency>
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>druid</artifactId>
<version>${druid.version}</version>
</dependency>
<dependency>
<groupId>org.mybatis.spring.boot</groupId>
<artifactId>mybatis-spring-boot-starter</artifactId>
<version>${mybatis.spring.boot.version}</version>
</dependency>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>${junit.version}</version>
</dependency>
<dependency>
<groupId>log4j</groupId>
<artifactId>log4j</artifactId>
<version>${log4j.version}</version>
</dependency>
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<version>${lombok.version}</version>
<optional>true</optional>
</dependency>
</dependencies>
</dependencyManagement>
<build>
<plugins>
<!-- 热部署需要的maven插件 -->
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
<configuration>
<fork>true</fork>
<addResources>true</addResources>
</configuration>
</plugin>
</plugins>
</build>
</project>