浅谈SpringCloud五大组件

spring cloud五大组件分别为:

  • 服务发现–Netflix Eureka
  • 客户端负载均衡–Netflix Ribbon
  • 断路器–Netflix Hystrix
  • 服务网关–Netflix Zuul
  • 分布式配置–Spring Cloud Config
    业务场景介绍:
    先来给大家说一个业务场景,假设咱们现在开发一个电商网站,要实现支付订单的功能,流程如下:
  • 创建一个订单之后,如果用户立刻支付了这个订单,我们需要将订单状态更新为”已支付”
  • 扣减相应的商品库存
  • 通知仓储中心,进行发货
  • 给用户的这次购物增加相应的积分

针对上述流程,我们需要有订单服务、库存服务、仓储服务、积分服务。整个流程的大体思路如下:

  • 用户针对一个订单完成支付之后,就会去找订单服务,更新订单状态
  • 订单服务调用库存服务,完成相应功能
  • 订单服务调用仓储服务,完成相应功能
  • 订单服务调用积分服务,完成相应功能

至此,整个支付订单的业务流程结束

  1. 核心组件Eureke(服务发现):
    是微服务架构中的注册中心,由Eureka Client和Eureka Server两部分组成,前者负责将各个服务的信息注册到Eureka Server中。后者为注册中心,里面有一个注册表,保存了各个服务所在的机器和端口号;
  2. 核心组件Feign(动态代理):
    使用了动态代理的机制,用注解定义一个FeignClient接口,向指定的服务建立连接、发起请求、获取响应,解析响应等等。
    Feign的动态代理机制:

  3. 首先,对某个接口定义了@FeignClient注解,Feign就会针对这个接口创建一个动态代理

  4. 接着你要是调用这个接口,本质就会调用Feign创建的动态代理,这是核心中的核心;
  5. Feign的动态代理会根据你接口上的@RequestMapping等注解,来动态构造出你要请求的服务地址;
  6. 最后针对这个地址,发起请求,解析响应;

  7. 核心组件Ribbon(客户端负载均衡):

  8. Ribbon的作用是负载均衡,当我们要请求的服务部署在多台机器上时,Feign就不知道该请求哪台机器。此时具有负载均衡作用的Ribbon就会帮你在每次请求时选择一台机器,均匀的把请求分发到各台机器上。

  9. Ribbon的负载均衡使用的是最经典的Round Robin轮询算法。简单说就是对多台机器进行轮流请求,然循环;
  10. 此外Ribbon是和Feign以及Eureka紧密协作的,具体如下:
  11. 首先Ribbon会从Eureka Client里获取到对应的服务注册表,知道所有的服务都部署在了哪些机器上,在监听哪些端口号。
  12. 然后Ribbon就使用默认的Round Robin轮询算法,从中选择一台机器;
  13. 最后Feign就会针对这台机器,构造并发起请求。

  14. 核心组件Hystrix(断路器)
    业务背景:

  15. 假设一个业务场景:订单服务在一个业务流程里需要调用三个服务。现在假设订单服务自己最多只有100个线程可以处理请求,然后呢,积分服务不幸的挂了,每次订单服务调用积分服务的时候,都会卡住几秒钟,然后抛出—个超时异常。这也是雪崩问题的雏形所在;

  16. 在上面的业务场景下,如果系统处于高并发状态,大量的请求涌过来的时候。订单服务的100个线程都会卡在请求积分服务这块儿。导致订单服务没有一个线程可以处理请求。然后就会导致别人请求订单服务的时候,发现订单服务也挂了,不响应任何请求了————这个,就是微服务架构中恐怖的服务雪崩问题。
    这边插入一个思考:就算积分服务挂了,订单服务也可以不挂啊?为什么?
    (1). 结合业务来看:支付订单的时候,只要把库存扣减了,然后通知仓库发货就OK了。
    (2). 如过积分服务挂了,大不了等他回复之后,慢慢人肉手工恢复数据!为啥一定要因为一个积分服务挂了,就直接导致订单服务也挂了呢?

分析了这么多,就是为了引出我们的Hystrix

  • Hystrix是隔离、熔断以及降级的一个框架。Hystrix会为每个服务搞一个小小的线程池。
    下面来说说,当有Hystrix参与时,积分服务挂了会是啥样的:
  • 因为上面说了,Hystrix会为各个服务搞一个线程池,当积分服务挂了时,订单服务那里用来调用积分服务的线程会都卡死不能工作。但是,订单服务调用库存服务和仓储服务的这两个线程池都能正常工作,所以这两个服务不会受到任何影响。
  • 熔断————这个时候如果别人调用订单服务,订单服务还可以正常调用库存服务扣减库存,调用仓储服务通知发货。当调用积分服务时每次都会报错。 但是既然积分服务挂了,每次调用都会卡几秒,这样显然是没有意义的。这里就要用到所谓的 熔断:比如在五分钟内请求积分服务直接就返回了,不要走网络请求卡住几秒钟。
  • 降级————上面说了,积分服务挂了我们就熔断然后直接返回,这显然不是最好的解决方法。这个时候就要用到 降级处理:每次调用积分服务时,就在数据库里记录一条消息,说给某某用户增加了多少积分,因为积分服务挂了,导致没增加成功!这样等积分服务恢复了,就可以根据这些记录手工加一下积分。这就是所谓的降级处理。
    *小结:针对微服务框架的服务雪崩问题,我们会用到Hystrix组件,然后进行隔离、熔断、降级处理。

  • 核心组件Zuul(服务网关)

  • Zuul就是微服务网关。这个组件是负责网络路由。

  • 如果不懂网络路由,那我们来看看,没有Zuul的工作会是怎么样的:
    假设你后台部署了几百个服务,现在有个前端兄弟,人家请求是直接从浏览器那儿发过来的。比如:人家要请求一下库存服务,你难道要让人家记住这个服务的名字叫什么什么?部署在几台机器上?但是后台可能有几百个服务的名称和地址,这显然不能靠记;
  • 上面这种情况压根儿是行不通的。所以一般微服务架构中都必然会设计一个网关在里面,像Android、iOS、PC前端、微信小程序、H5等等,不用去关心后端有几百个服务,就知道有一个网关,所有的请求都走网关,网关会根据请求中的一些特征,将请求转发给后端各个服务;而且有了网关之后还可以做统一的降级、限流、认证授权、安全,等等;
    总结:
  • Eureka:各个服务启动时,Eureka Client都会将服务注册到Eureka Server,并且Eureka Client还可以反过来从Eureka Server拉去注册表,从而知道其他服务在哪里;
    (在spring cloud中,除了可以使用eureka作为注册中心外,还可以使用zookeeper、Consul作为注册中心。)
  • Ribbon:服务间发起请求的时候,基于Ribbon做负载均衡,从一个服务的多台机器中选择一台;
  • Feign:基于Feign的动态代理机制,根据注解和选择的机器,拼接请求的URL地址,发起请求;
  • Hystrix:发起请求是通过Hystrix的线程池来走的,不同的服务走不同的线程池,实现了不同服务调用的隔离,避免了服务雪崩的问题;
    (Sentinel可以很好的替代Hystrix)
  • Zuul:如果前端、移动端要调用后端系统,统一从Zuul网关进入,由Zuul网关转发请求给对应的服务;
    (Gateway可以很好的替代Zuul)
    下面通过一张图来将Spring Cloud五组件联系起来,直观了解其底层的架构原理:
    浅谈SpringCloud五大组件
    (网络资源)

Original: https://www.cnblogs.com/mark5/p/16179178.html
Author: 双间
Title: 浅谈SpringCloud五大组件

原创文章受到原创版权保护。转载请注明出处:https://www.johngo689.com/541924/

转载文章受原作者版权保护。转载请注明原作者出处!

(0)

大家都在看

  • wordpress nginx详细环境配置安装命令和相关问题解决

    很详细的有关WordPress和nginx的环境配置安装操作步骤 指南,适合新手一步步按照命令操作安装WordPress并运行在生产环境中. 操作步骤转载自: Heap Stack…

    Java 2023年5月30日
    085
  • SpringBoot打包第三方本地jar包

    有一些包我们maven仓库找不到,那就只能在项目中引入本地jar包文件,但是maven打包的时候会显示没有这个jar包 首先我们把jar包放到resource下的lib文件夹 然后…

    Java 2023年5月30日
    074
  • Java import的作用

    可是现在问题来了,因為很多package的名称非常的长,在编程时,要使用一个类要将多个包名.类名完全写出,会让代码变得冗长,减低了简洁度。例如 显得非常麻烦,于是Sun公司就引入了…

    Java 2023年5月29日
    075
  • 图像处理

    绘制图像绘图类 不仅可以绘制几何图形, 还可以绘制图像,绘制图像需要使用 drawImage()方法 ,该方法用来将图像资源显示到绘图上下文中。drawImage()方法 语法: …

    Java 2023年6月9日
    060
  • SpringCloud + MyBatis Plus + Druid + dynamic-datasource 多数据源配置

    SpringCloud:Greenwich.SR2 Spring-boot : 2.1.7.RELEASE Spring:5.1.9.RELEASE 如果没有设置上文红色部分配置,…

    Java 2023年5月30日
    065
  • CSharp:Observer Pattern

    csharp;gutter:true; /// /// Summary description for Observer.</p> <pre><cod…

    Java 2023年6月16日
    077
  • Linux(一)——安装

    Linux(一)——安装 一、VMware Workstation Pro (一款虚拟机软件) 1.下载 打开网址https://www.vmware.com/cn.html跟着红…

    Java 2023年6月16日
    066
  • 后端编写Swagger接口管理文档

    在后端开发当中,编写好多个接口后需要通过注解编写相应的接口文档提供给前端调用接口实现前后端分离。 Swagger接口管理文档 访问接口文档的网页:http://localhost:…

    Java 2023年6月14日
    082
  • Java socket 多线程编程 示例

    参照网上代码: 1.工程: 2.代码: Client.java package com.my.socket.test; import java.io.BufferedReader;…

    Java 2023年5月29日
    077
  • 并发Map类删除数据的问题java.lang.UnsupportedOperationException: null

    笔者最近在开发Websocket相关的消息推送服务,使用了JSR356规范,由于需要维持会话。于是分别使用了以下类 笔者在维护失效的代码写了以下代码 最终在调用clients.re…

    Java 2023年5月29日
    076
  • AQS源码阅读

    AQS-获取资源: AQS-释放资源: posted @2022-06-22 17:07 無名之徒 阅读(9 ) 评论() 编辑 Original: https://www.cnb…

    Java 2023年6月13日
    081
  • 从芒果分装角度—看MapReduce流程

    有一芒果产销基地,园区内有芒果种植园(产), 芒果分装库(装),芒果销路(销)。芒果种植园即HDFS中的文件,这个种植园规模很大,有不同的山头,假设一个山头一个分区。芒果的品质不同…

    Java 2023年6月8日
    0127
  • MongoDB,入门看这一篇足矣!

    一、介绍 在介绍 MongoDB 之前,我先介绍一下业务开发的时候遇到的痛点,以便大家对它有一个更加清晰的认识! 最近在用数据库存储数据的时候发现这么一个坑,例如从消息队列中监听消…

    Java 2023年6月9日
    0107
  • SpringBoot加载资源方式及默认顺序

    注意:因为文件内容可能被覆盖,因此文件应用在项目中的优先级与文件的加载顺序相反。 一、同文件夹下加载properties文件和yml文件 springboot会首先加载类路径下的a…

    Java 2023年6月13日
    066
  • LeetCode.1103-向人们分发糖果(Distribute Candies to People)

    这是小川的第 393次更新,第 425篇原创 今天介绍的是 LeetCode算法题中 Easy级别的第 256题(顺位题号是 1103)。我们通过以下方式向一排 n = num_p…

    Java 2023年6月5日
    071
  • mybatis #与$区别

    mybatis #与$区别 {}变量解析到SQL有带引号字符串;如查询条件变量 如:select * from user where name = #{name};为:select…

    Java 2023年5月30日
    076
亲爱的 Coder【最近整理,可免费获取】👉 最新必读书单  | 👏 面试题下载  | 🌎 免费的AI知识星球