欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 新闻 > 国际 > Spring Cloud 微服务全面概述

Spring Cloud 微服务全面概述

2024/10/31 20:27:54 来源:https://blog.csdn.net/weixin_62818371/article/details/143261669  浏览:    关键词:Spring Cloud 微服务全面概述

Spring Cloud 微服务全面概述

1. 微服务架构概述

微服务架构(Microservices Architecture)是将应用程序拆分为多个小的、独立的服务,每个服务围绕特定的业务功能构建。这种架构使得应用程序能够更灵活地扩展和维护。

1.1 微服务的特点

  • 模块化:服务可以独立开发、测试、部署和扩展。
  • 异构技术:不同的服务可以使用不同的技术栈(编程语言、数据库等)。
  • 分布式:服务通常通过 HTTP REST、消息队列等网络协议通信。
  • 弹性:系统能在部分服务故障时保持可用。

1.2 微服务架构的优势

  • 可扩展性:可以根据需求独立扩展某些服务。
  • 开发效率:小团队可以并行开发不同的服务,加快交付速度。
  • 容错性:某个服务的失败不会导致整个系统崩溃。

2. Spring Cloud 介绍

Spring Cloud 是一套基于 Spring Boot 的开源工具,帮助开发者快速构建分布式系统。它提供了多个模块,支持服务发现、配置管理、负载均衡、断路器等功能。

2.1 Spring Cloud 的核心模块

  • Spring Cloud Netflix:提供了与 Netflix 生态系统集成的组件,如 Eureka、Ribbon、Hystrix、Zuul 等。
  • Spring Cloud Config:集中管理服务的配置。
  • Spring Cloud Gateway:API 网关,用于路由和负载均衡。
  • Spring Cloud Sleuth:提供分布式追踪功能。
  • Spring Cloud Bus:用于事件传播和配置更新。

3. Spring Cloud 核心知识点

3.1 服务注册与发现

Eureka 是一个服务注册与发现的组件。它允许微服务在启动时注册到 Eureka 服务器,并可以通过服务名查找其他服务。

3.1.1 Eureka 服务器的设置
  1. 添加依赖
    pom.xml 中添加 Eureka 服务器依赖:

    <dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-eureka-server</artifactId>
    </dependency>
    
  2. 主类配置
    在应用主类上添加 @EnableEurekaServer 注解,启动 Eureka 服务器。

    @SpringBootApplication
    @EnableEurekaServer
    public class EurekaServerApplication {public static void main(String[] args) {SpringApplication.run(EurekaServerApplication.class, args);}
    }
    
  3. 配置文件
    application.yml 中配置 Eureka 服务器:

    server:port: 8761
    eureka:client:register-with-eureka: falsefetch-registry: false
    
  4. 启动 Eureka 服务器
    运行应用,访问 http://localhost:8761 查看 Eureka Dashboard。

3.1.2 Eureka 客户端的设置
  1. 添加依赖
    在微服务的 pom.xml 中添加:

    <dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-eureka-client</artifactId>
    </dependency>
    
  2. 主类配置
    在微服务的主类上添加 @EnableEurekaClient 注解。

    @SpringBootApplication
    @EnableEurekaClient
    public class MyServiceApplication {public static void main(String[] args) {SpringApplication.run(MyServiceApplication.class, args);}
    }
    
  3. 配置文件
    application.yml 中配置 Eureka 客户端信息:

    spring:application:name: my-servicecloud:discovery:client:serviceUrl:defaultZone: http://localhost:8761/eureka/
    
  4. 服务启动
    启动微服务,查看 Eureka Dashboard 可以看到注册的服务。

3.2 负载均衡

Ribbon 是一个客户端负载均衡器,支持服务的自动负载均衡。

3.2.1 Ribbon 的设置
  1. 添加依赖
    在微服务的 pom.xml 中添加:

    <dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-ribbon</artifactId>
    </dependency>
    
  2. 使用 Ribbon
    在微服务中,可以使用 RestTemplate 发起请求,并利用 Ribbon 进行负载均衡。

    @Bean
    @LoadBalanced
    public RestTemplate restTemplate() {return new RestTemplate();
    }@GetMapping("/call-service")
    public String callOtherService() {return restTemplate.getForObject("http://my-service/api", String.class);
    }
    

3.3 API 网关

Spring Cloud Gateway 提供了一种简单的方式来路由请求到后端服务,支持负载均衡和安全性。

3.3.1 Gateway 的设置
  1. 添加依赖
    pom.xml 中添加:

    <dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-gateway</artifactId>
    </dependency>
    
  2. 配置路由
    application.yml 中配置路由规则:

    spring:cloud:gateway:routes:- id: my-service-routeuri: lb://my-servicepredicates:- Path=/my-service/**
    
  3. 访问网关
    启动网关服务后,通过网关访问后端服务,例如 http://localhost:8080/my-service/api

3.4 配置管理

Spring Cloud Config 提供了集中管理微服务配置的功能。

3.4.1 Config 服务器的设置
  1. 添加依赖
    在 Config 服务器的 pom.xml 中添加:

    <dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-config-server</artifactId>
    </dependency>
    
  2. 启用 Config 服务器
    在主类上添加 @EnableConfigServer 注解。

    @SpringBootApplication
    @EnableConfigServer
    public class ConfigServerApplication {public static void main(String[] args) {SpringApplication.run(ConfigServerApplication.class, args);}
    }
    
  3. 配置 Git 仓库
    application.yml 中配置 Git 仓库地址:

    spring:cloud:config:server:git:uri: https://github.com/your-repo/config-repo
    
  4. 客户端配置
    微服务客户端在 application.yml 中配置:

    spring:application:name: my-servicecloud:config:uri: http://localhost:8888
    

3.5 断路器

Hystrix 是一个用于服务容错的库,通过断路器模式来保护服务。

3.5.1 Hystrix 的设置
  1. 添加依赖
    在微服务的 pom.xml 中添加:

    <dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-hystrix</artifactId>
    </dependency>
    
  2. 启用 Hystrix
    在主类上添加 @EnableCircuitBreaker 注解。

    @SpringBootApplication
    @EnableCircuitBreaker
    public class MyServiceApplication {public static void main(String[] args) {SpringApplication.run(MyServiceApplication.class, args);}
    }
    
  3. 使用 Hystrix 注解
    在需要保护的方法上使用 @HystrixCommand 注解:

    @HystrixCommand(fallbackMethod = "fallbackMethod")
    public String callExternalService() {// 可能会失败的外部调用
    }public String fallbackMethod() {return "服务暂时不可用,请稍后再试";
    }
    

好的,我们接着讲解 Spring Cloud Bus 的设置以及其他相关内容。

3.6 消息总线

Spring Cloud Bus 可以用于将配置更改、事件等信息广播到所有服务实例,从而实现服务间的事件传播和配置更新。

3.6.1 消息总线的设置
  1. 添加依赖
    在微服务的 pom.xml 中添加 RabbitMQ 或 Kafka 相关依赖。这里以 RabbitMQ 为例:

    <dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-bus-amqp</artifactId>
    </dependency>
    <dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-rabbit</artifactId>
    </dependency>
    
  2. 配置 RabbitMQ
    application.yml 中配置 RabbitMQ 的连接信息:

    spring:rabbit:host: localhostport: 5672username: guestpassword: guest
    
  3. 发送事件
    在微服务中,使用 @RefreshScope 注解来自动刷新配置:

    @RefreshScope
    @RestController
    public class MyController {@Value("${my.property}")private String myProperty;@GetMapping("/property")public String getProperty() {return myProperty;}
    }
    

    当配置发生变化时,发送 POST 请求到 /bus/refresh 来通知所有服务更新配置:

    curl -X POST http://localhost:8888/bus/refresh
    

4. 实际案例

下面是一个简单的微服务案例,演示如何将前面的组件整合在一起。

4.1 项目结构
/microservices/eureka-server/config-server/gateway/service-a/service-b
4.2 Eureka 服务器

使用之前介绍的方法设置 Eureka 服务器。

4.3 Config 服务器

使用之前介绍的方法设置 Config 服务器,并在 Git 仓库中存放配置文件,如 application.yml

4.4 微服务 A 和 B
  1. 创建微服务 A

    @SpringBootApplication
    @EnableEurekaClient
    @EnableCircuitBreaker
    public class ServiceAApplication {public static void main(String[] args) {SpringApplication.run(ServiceAApplication.class, args);}@HystrixCommand(fallbackMethod = "fallbackMethod")public String callServiceB() {// 通过服务名调用服务 Breturn restTemplate.getForObject("http://service-b/endpoint", String.class);}public String fallbackMethod() {return "服务 B 暂时不可用";}
    }
    
  2. 创建微服务 B

    @SpringBootApplication
    @EnableEurekaClient
    public class ServiceBApplication {public static void main(String[] args) {SpringApplication.run(ServiceBApplication.class, args);}@GetMapping("/endpoint")public String endpoint() {return "Hello from Service B";}
    }
    
4.5 Gateway

配置 Gateway,以便路由请求到微服务 A 和 B。

spring:cloud:gateway:routes:- id: service-auri: lb://service-apredicates:- Path=/service-a/**- id: service-buri: lb://service-bpredicates:- Path=/service-b/**

5. 总结

通过使用 Spring Cloud 的一系列组件,你可以快速构建一个健壮的微服务架构,具备服务发现、负载均衡、断路器、配置管理等特性。每个组件都能为你的微服务提供必要的功能,帮助你提高开发效率和系统的可靠性。

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com