Spring Cloud 常用各个组件详解及实现原理(附加源码+实现逻辑图)

本文涉及的产品
传统型负载均衡 CLB,每月750个小时 15LCU
应用型负载均衡 ALB,每月750个小时 15LCU
EMR Serverless StarRocks,5000CU*H 48000GB*H
简介: Spring Cloud 常用各个组件详解及实现原理(附加源码+实现逻辑图)


Eureka

注册中心组件,主要是用来做服务注册和服务发现的
每个服务在创建时,指定注册地址(往哪个Eureka中进行注册),又做了服务集群操作,当某个服务器挂了之后,不会影响其它服务的正常使用

Ribbon

是客户端实现负载均衡的远程调用组件起到一个中间的作用
实现方式:
  第一种是:ribbon和RestTemplate相结合使用,请求路径传给RestTemlate,利用负载均衡轮训算法完成调用
  第二种是:ribbon和OpenFeign相结合使用(发起一个远程调用,同时完成负载均衡的任务)
实现原理:
  1.通过用 Eureka-Client来做服务发现
  2.通过RestTemplate来完成服务调用上面和eureka结合,下面和IRule,实现负载均衡eureka服务发现

Open Feign

Open Feign远程调用组件
Feign集成了ribbon(不懂的可以去看下ribbon实现原理,这里直接上图解)
实现方式:
  A服务Controller开启@EnableFeignClients,在A服务接口类中添加注解@FeignClient(value = "order-service")指定调用的服务名称,参数格式要求下方图中查看

Gateway

网关组件:根据微服务名称,创建动态路进行转发,实现动态路由功能
动态路由优点:
当服务注册时,不需要重启服务端,动态去做负载均衡、服务发现,只需要加上服务名称即可
Geteway 的核心逻辑:路由转发+执行过滤器链
Gateway是web网关,处理的是Http请求

Hystrix

保护服务组件:保护微服务不雪崩,提供了熔断功能,能够阻止分布式系统中联动故障
hystrix通常和Openfeign和ribbon一起使用
hystrix本质是:代理feign的请求,才能完成熔断效果
hystrix实现原理:
  指定熔断的类,注解:@FeignClient(value = "rent-car-service",fallback = CustomerRentFeignHystrix.class)

定义熔断类

调用熔断类

下面说下断路器实现流程,先来说下为什么要使用断路器?

在微服务分布式架构开发中,会有很多独立的服务,当A服务去调用B服务时,一次发现没有反应,当A服务疯狂调用时,
B服务还是没有响应,这是猜测可能是B服务挂了,断路器作用就是当A要访问B服务时,拦截器知道B服务当前的一个状态,
正常继续使用,如果挂了直接return,类同于Hystrix

Nacos-feign

动态服务发现,配置管理和服务管理的平台
注册中心和配置文件中心
有登录验证
可以通过命名空间的形式进行调用服务,避免Nacos中出现重名的服务名称
实现原理:
  1. nacos-client-a 通过feign结合ribbon发起远程调用info接口
  2. @EnableDiscoveryClient // 开启服务发现客户端()
  3. @FeignClient(value = "user-service")(要调用对象的服务名称)

向Nacos中注册服务时,需指定nacos地址和用户名和密码以及命名空间、组

Nacos-配置中心

默认读取nacos配置中心文件 yml配置

Nginx和GeteWay区别

相关实践学习
SLB负载均衡实践
本场景通过使用阿里云负载均衡 SLB 以及对负载均衡 SLB 后端服务器 ECS 的权重进行修改,快速解决服务器响应速度慢的问题
负载均衡入门与产品使用指南
负载均衡(Server Load Balancer)是对多台云服务器进行流量分发的负载均衡服务,可以通过流量分发扩展应用系统对外的服务能力,通过消除单点故障提升应用系统的可用性。 本课程主要介绍负载均衡的相关技术以及阿里云负载均衡产品的使用方法。
目录
相关文章
|
6天前
|
监控 负载均衡 Java
5 大 SpringCloud 核心组件详解,8 张图彻底弄懂
本文图文详解 Spring Cloud 的五大核心组件,帮助深入理解和掌握微服务架构。关注【mikechen的互联网架构】,10年+BAT架构经验倾囊相授。
5 大 SpringCloud 核心组件详解,8 张图彻底弄懂
|
3天前
|
监控 Java 应用服务中间件
高级java面试---spring.factories文件的解析源码API机制
【11月更文挑战第20天】Spring Boot是一个用于快速构建基于Spring框架的应用程序的开源框架。它通过自动配置、起步依赖和内嵌服务器等特性,极大地简化了Spring应用的开发和部署过程。本文将深入探讨Spring Boot的背景历史、业务场景、功能点以及底层原理,并通过Java代码手写模拟Spring Boot的启动过程,特别是spring.factories文件的解析源码API机制。
14 2
|
19天前
|
数据采集 监控 前端开发
二级公立医院绩效考核系统源码,B/S架构,前后端分别基于Spring Boot和Avue框架
医院绩效管理系统通过与HIS系统的无缝对接,实现数据网络化采集、评价结果透明化管理及奖金分配自动化生成。系统涵盖科室和个人绩效考核、医疗质量考核、数据采集、绩效工资核算、收支核算、工作量统计、单项奖惩等功能,提升绩效评估的全面性、准确性和公正性。技术栈采用B/S架构,前后端分别基于Spring Boot和Avue框架。
|
9天前
|
前端开发 Java 开发者
Spring生态学习路径与源码深度探讨
【11月更文挑战第13天】Spring框架作为Java企业级开发中的核心框架,其丰富的生态系统和强大的功能吸引了无数开发者的关注。学习Spring生态不仅仅是掌握Spring Framework本身,更需要深入理解其周边组件和工具,以及源码的底层实现逻辑。本文将从Spring生态的学习路径入手,详细探讨如何系统地学习Spring,并深入解析各个重点的底层实现逻辑。
35 9
|
9天前
|
负载均衡 算法 Java
除了 Ribbon,Spring Cloud 中还有哪些负载均衡组件?
这些负载均衡组件各有特点,在不同的场景和需求下,可以根据项目的具体情况选择合适的负载均衡组件来实现高效、稳定的服务调用。
23 5
|
1月前
|
Java Spring
Spring底层架构源码解析(三)
Spring底层架构源码解析(三)
108 5
|
Dubbo Java 应用服务中间件
深入了解Spring Cloud Alibaba Dubbo
在现代分布式系统开发中,构建高性能、可伸缩性和弹性的微服务架构变得越来越重要。Spring Cloud Alibaba Dubbo(简称Dubbo)是一个开源的分布式服务框架,可以帮助开发者构建强大的微服务架构,具备负载均衡、服务治理、远程调用等强大功能。本文将深入介绍Spring Cloud Alibaba Dubbo,帮助你理解它的核心概念、工作原理以及如何在你的项目中使用它。
|
Kubernetes Java 微服务
Spring Boot 单体应用一键升级成 Spring Cloud Alibaba(1)
Spring Boot 单体应用一键升级成 Spring Cloud Alibaba(1)
135 0
Spring Boot 单体应用一键升级成 Spring Cloud Alibaba(1)
|
6月前
|
Java 中间件 开发者
Spring Cloud Alibaba
【1月更文挑战第27天】【1月更文挑战第127篇】Spring Cloud Alibaba
140 1
|
5月前
|
消息中间件 Java 持续交付
Spring Cloud Alibaba 项目搭建步骤和注意事项
Spring Cloud Alibaba 项目搭建步骤和注意事项
784 0
Spring Cloud Alibaba 项目搭建步骤和注意事项