Spring Cloud五大组件以及工作原理

Spring Cloud 是一系列框架的有序集合,用于快速构建分布式系统的技术集合。它集成了Spring Boot,提供了服务发现与注册,配置中心,负载均衡,断路器,智能路由,微代理,控制总线等操作,都是用服务网格进行连接。

五大组件分别是:

  1. 服务发现——Netflix Eureka

    Eureka 提供了服务发现的功能,它被用来在微服务系统中发现其他服务。服务端通过Eureka Server进行注册,客户端通过Eureka Server进行服务的发现和请求。

  2. 客户端负载均衡——Netflix Ribbon

    Ribbon 是一个负载均衡器,可以将多个服务实例的请求分配到不同的服务实例。

  3. 断路器——Netflix Hystrix

    Hystrix 是一个用于处理分布式系统的延迟和容错的库,可以防止系统间的级联故障,提高系统的弹性。

  4. 服务网关——Netflix Zuul

    Zuul 是一种提供路由,监控,弹性,安全等边缘服务的系统。

  5. 分布式配置——Spring Cloud Config

    Config 可以为微服务系统提供一个中心化的外部配置。

工作原理简述:

  1. 服务提供者在启动时,将自己的服务信息注册到Eureka Server。
  2. 服务消费者通过Eureka Server获取服务提供者的信息,并通过Ribbon进行调用。
  3. 服务之间通过Feign进行通信,Feign默认集成了Ribbon。
  4. 断路器Hystrix负责调用远程服务的线程池,并监控服务的状态,如果服务出现故障,则直接返回错误,不进行服务的连接。
  5. Zuul通过过滤器进行请求的路由,并可实现权限校验,请求限流等功能。
  6. 配置中心可以实现配置的动态更新。
最后修改于:2024年09月02日 16:48

评论已关闭

推荐阅读

DDPG 模型解析,附Pytorch完整代码
2024年11月24日
DQN 模型解析,附Pytorch完整代码
2024年11月24日
AIGC实战——Transformer模型
2024年12月01日
Socket TCP 和 UDP 编程基础(Python)
2024年11月30日
python , tcp , udp
如何使用 ChatGPT 进行学术润色?你需要这些指令
2024年12月01日
AI
最新 Python 调用 OpenAi 详细教程实现问答、图像合成、图像理解、语音合成、语音识别(详细教程)
2024年11月24日
ChatGPT 和 DALL·E 2 配合生成故事绘本
2024年12月01日
omegaconf,一个超强的 Python 库!
2024年11月24日
【视觉AIGC识别】误差特征、人脸伪造检测、其他类型假图检测
2024年12月01日
[超级详细]如何在深度学习训练模型过程中使用 GPU 加速
2024年11月29日
Python 物理引擎pymunk最完整教程
2024年11月27日
MediaPipe 人体姿态与手指关键点检测教程
2024年11月27日
深入了解 Taipy:Python 打造 Web 应用的全面教程
2024年11月26日
基于Transformer的时间序列预测模型
2024年11月25日
Python在金融大数据分析中的AI应用(股价分析、量化交易)实战
2024年11月25日
AIGC Gradio系列学习教程之Components
2024年12月01日
Python3 `asyncio` — 异步 I/O,事件循环和并发工具
2024年11月30日
llama-factory SFT系列教程:大模型在自定义数据集 LoRA 训练与部署
2024年12月01日
Python 多线程和多进程用法
2024年11月24日
Python socket详解,全网最全教程
2024年11月27日