【Spring Cloud】微服务开发框架简单介绍与使用示例

Spring Cloud 是一个基于 Spring Boot 构建的微服务开发框架,提供了一整套解决微服务架构中常见问题的工具和库。通过 Spring Cloud,开发者可以轻松地构建和管理复杂的微服务应用程序,并解决微服务架构中遇到的常见挑战,如服务注册与发现、配置管理、负载均衡、熔断、网关、分布式追踪等。

在这篇介绍中,我们将深入探讨 Spring Cloud 的主要组件和特性,并通过一些示例来展示如何使用 Spring Cloud 构建微服务应用程序。

为什么选择微服务架构?

在讨论 Spring Cloud 之前,我们先来了解一下为什么许多公司选择微服务架构:

  1. 可独立部署:每个微服务可以独立部署和更新,不会影响到其他服务。这种独立性极大地提高了系统的灵活性。

  2. 技术栈多样性:不同的微服务可以使用不同的技术栈,根据需要选择最佳工具。例如,可以用 Java 开发一个微服务,而另一个微服务可以用 Python 或 Node.js。

  3. 更好的可扩展性:可以根据需要单独扩展每个微服务,增加其实例数量,以满足不同的业务需求和流量波动。

  4. 故障隔离:某个微服务的故障不会直接导致整个系统的崩溃,提高了系统的鲁棒性。

  5. 团队独立性:不同的团队可以负责不同的微服务,减少了沟通成本和开发协作上的瓶颈。

Spring Cloud 的核心组件

Spring Cloud 提供了一整套的工具和组件,以下是 Spring Cloud 的一些核心组件:

  1. Spring Cloud Netflix:提供了一套基于 Netflix 开源项目的工具,包括服务发现、负载均衡、熔断器、智能路由、服务网关等。

  2. Spring Cloud Config:外部配置管理组件,支持集中式的配置服务,能够从 Git、SVN 等版本控制系统中读取配置。

  3. Spring Cloud Gateway:API 网关解决方案,提供路由、过滤、限流等功能。

  4. Spring Cloud OpenFeign:声明式 REST 客户端,简化了服务间的 HTTP 请求调用。

  5. Spring Cloud Circuit Breaker:提供熔断机制,帮助微服务在出现故障时快速失败并提供备用逻辑。

  6. Spring Cloud Sleuth:分布式追踪工具,集成了 Zipkin 和 Brave,帮助追踪微服务之间的调用链路。

  7. Spring Cloud Security:用于保护微服务的安全框架,支持 OAuth2、JWT、SAML 等协议。

  8. Spring Cloud Kubernetes:将 Spring Cloud 的能力扩展到 Kubernetes 平台,支持服务发现、配置管理等功能。

  9. Spring Cloud Stream:为微服务提供消息驱动的能力,支持 Kafka、RabbitMQ 等消息中间件。

  10. Spring Cloud Task:简化短期任务(如批处理任务)的开发与执行。

Spring Cloud 微服务架构示例

下面我们将创建一个简单的微服务架构示例,包括以下几个模块:

  1. 创建主项目(spring-cloud-project)
  2. 服务注册与发现(Eureka Server)
  3. 配置中心(Spring Cloud Config Server)
  4. 服务提供者(User Service)
  5. 服务消费者(Order Service)
  6. 网关(Spring Cloud Gateway)
1. 创建主项目(spring-cloud-project)

首先,创建一个 主项目并添加相关依赖:
Maven 配置(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 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>

    <groupId>com.example</groupId>
    <artifactId>spring-cloud-project</artifactId>
    <version>1.0-SNAPSHOT</version>
    <packaging>pom</packaging>
    <modules>
        <module>eureka-server</module>
        <module>config-server</module>
        <module>user-service</module>
        <module>order-service</module>
        <module>gateway-server</module>
    </modules>
    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>3.1.5</version>
    </parent>

    <properties>
        <java.version>17</java.version>
        <spring-cloud.version>2022.0.5</spring-cloud.version>
        <mysql.version>8.0.33</mysql.version>
        <druid.version>1.2.23</druid.version>
        <lombok.version>1.18.34</lombok.version>
        <mybatis-plus.version>3.5.7</mybatis-plus.version>

        <maven.compiler.source>17</maven.compiler.source>
        <maven.compiler.target>17</maven.compiler.target>
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
    </properties>
    <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>
        </dependencies>
    </dependencyManagement>

    <dependencies>
        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
            <version>${lombok.version}</version>
        </dependency>
    </dependencies>

    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
            </plugin>
        </plugins>
    </build>
</project>
2. 服务注册与发现 - Eureka Server

服务注册与发现是微服务架构中的重要组成部分,用于管理微服务的实例信息。Eureka 是 Netflix 开源的一个服务注册和发现组件,Spring Cloud 提供了对 Eureka 的良好支持。

创建 Eureka Server 子项目
添加依赖到 pom.xml

Maven 配置(pom.xml:

 <dependencies>
     <!-- Eureka Server 依赖 -->
     <dependency>
         <groupId>org.springframework.cloud</groupId>
         <artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
         <version>4.1.0</version>
     </dependency>

     <!-- Spring Boot Web Starter -->
     <dependency>
         <groupId>org.springframework.boot</groupId>
         <artifactId>spring-boot-starter-web</artifactId>
     </dependency>
 </dependencies>

主应用类(EurekaServerApplication.java:

package com.example.eurekaserver;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.netflix.eureka.server.EnableEurekaServer;

@SpringBootApplication
@EnableEurekaServer // 启用 Eureka Server
public class EurekaServerApplication {
    
    

    public static void main(String[] args) {
    
    
        SpringApplication.run(EurekaServerApplication.class, args);
    }
}

配置文件(application.yml:

server:
  port: 8761

eureka:
  instance:
    hostname: localhost
  client:
    register-with-eureka: false # 表示这个服务不会向 Eureka Server 注册自己
    fetch-registry: false # 不需要从 Eureka Server 获取服务注册列表

启动应用程序后,可以在浏览器中访问 http://localhost:8761 查看 Eureka Dashboard,确认服务启动成功。

3. 配置中心 - Spring Cloud Config Server

Spring Cloud Config Server 是一个集中式配置管理中心,可以为不同环境提供不同的配置集。

创建 Config Server 子项目

添加依赖到 pom.xml

<dependencies>
    <!-- Spring Cloud Config Server 依赖 -->
    <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-config-server</artifactId>
    </dependency>

    <!-- Spring Boot Web Starter -->
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-web</artifactId>
    </dependency>

    <!-- Spring Cloud Eureka Client 依赖 -->
    <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
    </dependency>
</dependencies>

主应用类(ConfigServerApplication.java:

package com.example.configserver;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.config.server.EnableConfigServer;

@SpringBootApplication
@EnableConfigServer // 启用配置服务器
public class ConfigServerApplication {
    
    

    public static void main(String[] args) {
    
    
        SpringApplication.run(ConfigServerApplication.class, args);
    }
}

配置文件(application.yml:

server:
  port: 8888

spring:
  cloud:
    config:
      server:
        git:
          uri: https://github.com/your-repo/config-repo # 配置文件的 Git 仓库
          search-paths: your-app
  application:
    name: config-server

eureka:
  client:
    service-url:
      defaultZone: http://localhost:8761/eureka/

在配置服务器启动后,它将从 Git 仓库中读取配置文件,并根据请求返回相应的配置。

4. 服务提供者 - User Service

服务提供者是负责提供具体业务功能的微服务。在这个示例中,我们将创建一个简单的用户服务。

创建 User Service 子项目

添加依赖到 pom.xml

<dependencies>
    <!-- Spring Boot Web Starter -->
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-web</artifactId>
    </dependency>

    <!-- Spring Cloud Eureka Client 依赖 -->
    <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
    </dependency>

    <!-- Spring Cloud Config Client 依赖 -->
    <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-starter-config</artifactId>
    </dependency>
</dependencies>

主应用类(UserServiceApplication.java:

package com.example.userservice;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.client.discovery.EnableDiscoveryClient;

@SpringBootApplication
@EnableDiscoveryClient // 启用 Eureka 客户端
public class UserServiceApplication {
    
    

    public static void main(String[] args) {
    
    
        SpringApplication.run(UserServiceApplication.class, args);
    }
}

控制器(UserController.java:

package com.example.userservice.controller;

import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

@RestController
@RequestMapping("/user")
public class UserController {
    
    

    @GetMapping("/info")
    public String getUserInfo() {
    
    
        return "User Info: John Doe, Age: 30";
    }
}

配置文件(application.yml:

server:
  port: 8081

spring:
  config:
    import: optional:configserver:http://localhost:8888
  application:
    name: user-service

eureka:
  client:
    service-url:
      defaultZone: http://localhost:8761/eureka/
5. 服务消费者 - Order Service

服务消费者是调用其他微服务的应用程序。在这个示例中,我们将创建一个订单服务,通过它来调用用户服务。

创建 Order Service 子项目

添加依赖到 pom.xml

<dependencies>
    <!-- Spring Boot Web Starter -->
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-web</artifactId>
    </dependency>

    <!-- Spring Cloud Eureka Client 依赖 -->
    <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
    </dependency>

    <!-- Spring Cloud OpenFeign 依赖 -->
    <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-starter-openfeign</artifactId>
    </dependency>

    <!-- Spring Cloud Config Client 依赖 -->
    <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-starter-config</artifactId>
    </dependency>
</dependencies>

主应用类(OrderServiceApplication.java:

package com.example.orderservice;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.client.discovery.EnableDiscoveryClient;
import org.springframework.cloud.openfeign.EnableFeignClients;

@SpringBootApplication
@EnableDiscoveryClient // 启用 Eureka 客户端
@EnableFeignClients // 启用 OpenFeign 客户端
public class OrderServiceApplication {
    
    

    public static void main(String[] args) {
    
    
        SpringApplication.run(OrderServiceApplication.class, args);
    }
}

Feign 客户端(UserClient.java:

package com.example.orderservice.client;

import org.springframework.cloud.openfeign.FeignClient;
import org.springframework.web.bind.annotation.GetMapping;

@FeignClient(name = "user-service") // 指定要调用的服务名称
public interface UserClient {
    
    

    @GetMapping("/user/info")
    String getUserInfo();
}

控制器(OrderController.java:

package com.example.orderservice.controller;

import com.example.orderservice.client.UserClient;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

@RestController
@RequestMapping("/order")
public class OrderController {
    
    

    @Autowired
    private UserClient userClient;

    @GetMapping("/details")
    public String getOrderDetails() {
    
    
        String userInfo = userClient.getUserInfo();
        return "Order Details: [Item: Book, Quantity: 2, " + userInfo + "]";
    }
}

配置文件(application.yml:

server:
  port: 8082

spring:
  config:
    import: optional:configserver:http://localhost:8888
  application:
    name: order-service

eureka:
  client:
    service-url:
      defaultZone: http://localhost:8761/eureka/
6. API 网关 - Spring Cloud Gateway

Spring Cloud Gateway 是一个功能强大的 API 网关,它提供了路由和过滤功能,能够帮助我们轻松管理微服务的入口。

创建 Gateway 子项目

添加依赖到 pom.xml

<dependencies>
    <!-- Spring Cloud Gateway 依赖 -->
    <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-starter-gateway</artifactId>
    </dependency>

    <!-- Spring Cloud Eureka Client 依赖 -->
    <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
    </dependency>

    <!-- Spring Boot Web Starter -->
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-web</artifactId>
    </dependency>
</dependencies>

主应用类(GatewayApplication.java:

package com.example.gateway;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.client.discovery.EnableDiscoveryClient;

@SpringBootApplication
@EnableDiscoveryClient // 启用 Eureka 客户端
public class GatewayApplication {
    
    

    public static void main(String[] args) {
    
    
        SpringApplication.run(GatewayApplication.class, args);
    }
}

配置文件(application.yml:

server:
  port: 8080

spring:
  application:
    name: api-gateway
  cloud:
    gateway:
      routes:
        - id: user-service
          uri: lb://user-service
          predicates:
            - Path=/user/**
        - id: order-service
          uri: lb://order-service
          predicates:
            - Path=/order/**

eureka:
  client:
    service-url:
      defaultZone: http://localhost:8761/eureka/

运行与测试

  1. 启动各个服务:按以下顺序启动 Eureka Server、Config Server、User Service、Order Service 和 Gateway。

  2. 测试服务

  3. 监控 Eureka Dashboard:访问 http://localhost:8761 可以看到注册到 Eureka 的所有服务实例。

总结

通过上述示例,我们创建了一个简单的 Spring Cloud 微服务架构,包括服务注册与发现、配置中心、服务提供者、服务消费者和网关等组件。每个微服务可以独立开发和部署,并通过 Eureka 进行注册和发现。Spring Cloud 提供了一整套解决方案来管理和优化微服务架构中的常见问题,帮助开发者构建更稳定、高效的微服务应用程序。

随着业务需求的增加,您可以根据具体需求进一步扩展微服务架构,并结合 Spring Cloud 的其他功能来满足更多复杂场景下的开发需求。

猜你喜欢

转载自blog.csdn.net/u013675821/article/details/140849445