SpringCloud01-简介

SpringCloud01-简介

1.微服务是什么?

  1. 微服务就是将单一应用程序划分成一组小的服务,每个服务运行在独立的进程内,服务直接相互协调,相互配置,最终为用户提供统一的服务。
  2. 服务之间采用轻量级的通信机制相互沟通,每个服务围绕具体的业务进行构建,并且能够被独立部署到生成环境中。
  3. 微服务的优点:每个微服务单一职责,高内聚,低耦合;容易和第三方集成,使得微服务可以集成自动部署,如Jenkins......
  4. 在构建微服务时需要考虑的问题。
    1. 服务之间如何通信问题。解决方案:RestTemplate+Ribbon 或者 OpenFeign。
    2. 服务之间的调度,如何避免扇出、雪崩等问题?解决方案:Hystrix 或者 Sentinel。
    3. 如何维护服务提供者的统一状态?解决方案:使用注册中心,如Eureka、Zookeeper、Consul、Nacos......
    4. 网关。Zuul 和 Gateway。
  5. 关于微服务的文章。http://www.bdata-cap.com/newsinfo/1713874.html

2.SpringCloud是什么?

  1. SpringCloud是一个全局的服务器治理框架,是分布式微服务架构一站式解决方案,是多种微服务架构落地的技术的集合体。
  2. SpringCloud借助Springboot可以快速的构建起一个又一个的微服务。
  3. SpringCloud官网文档地址。https://docs.spring.io/spring-cloud/docs/2020.0.3/reference/htmlsingle/
  4. 查看SpringCloud和Springboot版本的对应关系。https://start.spring.io/actuator/info
  5. SpringCloud源码地址。https://github.com/spring-cloud
  6. SpringCloud官网架构图。

image

3.SpringCloud组件说明

  1. 注册中心。Eukeka(停止维护)、Zookeeper、Consul、Nacos(推荐使用)。
  2. 服务调用1。Ribbon(停止维护)、LoadBalancer(出自Spring社区)。
  3. 服务调用2。Feign(停止维护)、OpenFeign(Spring社区,推荐使用)。
  4. 服务降级。Hystrix(停止维护)、Resilience4j(国外推荐使用)、Sentinel(国内推荐使用)。
  5. 服务网关。Zuul(不推荐)、Zuul2、Gateway(Spring社区,推荐使用)。
  6. 服务配置。Config(停止维护)、Apolo(阿波罗)、Nacos(推荐使用)。
  7. 服务总线。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>
posted @ 2021-10-07 19:45  行稳致远方  阅读(19)  评论(0)    收藏  举报