Spring Cloud Hystrix简介说明

乔欣 Spring Cloud 发布时间:2022-11-21 22:16:20 阅读数:2495 1
下文笔者讲述Spring Cloud Hystrix简介说明,如下所示

Spring Cloud Hystrix简介

Spring Cloud Hystrix:
   由Netflix开源的一个延迟和容错库
   用于隔离访问远程系统、服务或者第三方库
     防止级联失败
 从而提升系统的可用性、容错性与局部应用的弹性
  是一个实现了超时机制和断路器模式的工具类库

Spring Cloud Hystrix的功能

1.切断:
   防止单独的依赖耗尽线程资源
   过载立即切断并快速失败,防止扎堆排队

2.回调:
   提供有效返回,以保护用户免受故障

3.隔离:
   使用隔离技术(例隔板,泳道和断路器模式)
     来限制任何一个依赖的影响

4.监控:
   通过实时的指标
     监控和告警
   确保故障被及时发现

5.恢复:
   通过动态修改配置属性
   确保故障及时恢复

6.防止整个依赖客户端执行失败,而不仅仅是网络通信

Spring Cloud Hystrix的特性

请求熔断

 当Hystrix Command请求后端服务失败数量超过一定比例(缺省50%)
    断路器会切换到开路状态(Open)
  此时,所有请求会直接失败而不会发送到后端服务

断路器保持在开路状态一段时间后(缺省5秒)
  自动切换到半开路状态(HALF-OPEN)
 此时会判断下一次请求的返回情况
 如果请求成功,断路器切回闭路状态(CLOSED),否则重新切换到开路状态(OPEN)

Hystrix的断路器
   就像电路保险丝
   一旦后端服务不可用
   断路器会直接切断请求链
   避免发送大量无效请求影响系统吞吐量
   并且断路器有自我检测并恢复的能力

服务降级

Fallback相当于是降级操作
 对于查询操作,
 可实现一个fallback方法,
 当请求后端服务出现异常的时,
 使用fallback方法的返回值

 fallback方法的返回值一般是设置的默认值或者来自缓存
  告知后面的请求服务不可用,不要再请求

依赖隔离

在Hystrix中
 主要通过线程池来实现资源隔离
通常在使用的时候我们会根据调用的远程服务划分出多个线程池

如:一个服务调用两外两个服务
   你如果调用两个服务都用一个线程池
   那么如果一个服务卡在哪里
   资源没被释放后面的请求又来了
    导致后面的请求都卡在哪里等待
    导致你依赖的A服务把你卡在哪里,耗尽资源
    也导致你另外一个B服务也不可用

    这时如果依赖隔离,某一个服务调用A B两个服务,如果这时我有100个线程可用
	我给A服务分配50个
      给B服务分配50个
     这样就算A服务挂了,我的B服务依然可以用

请求缓存

如:
 一个请求过来请求我userId=1的数据
 你后面的请求也过来请求同样的数据
  这时我不会继续走原来的那条请求链路了
   而是把第一次请求缓存过了
   把第一次的请求结果返回给后面的请求

请求合并

   请求依赖于同一服务
  要调用N次
如:
 说查数据库,发了N条请求发了N条SQL然后拿到一堆结果
 这时候我们可以把多个请求合并成一个请求
  发送一个查询多条数据的SQL的请求
  这样我们只需查询一次数据库
  提升了效率

Spring Cloud Hystrix的原理

1.使用命令模式将所有对外部服务(或依赖关系)的调用包装在HystrixCommand或HystrixObservableCommand对象中
  并将该对象放在单独的线程中执行

2.每个依赖都维护着一个线程池(或信号量)
 线程池被耗尽则拒绝请求(而不是让请求排队)

3.记录请求成功,失败,超时和线程拒绝

4.服务错误百分比超过了阈值,熔断器开关自动打开,一段时间内停止对该服务的所有请求

5.请求失败,被拒绝,超时或熔断时执行降级逻辑

6.近实时地监控指标和配置的修改
  当使用Hystrix封装每个基础依赖项时,每个依赖项彼此隔离,
  受到延迟时发生饱和的资源的限制,
  并包含回退逻辑,
  该逻辑决定了在依赖项中发生任何类型的故障时做出什么响应
版权声明

本文仅代表作者观点,不代表本站立场。
本文系作者授权发表,未经许可,不得转载。

本文链接: https://www.Java265.com/JavaFramework/SpringCloud/202211/4959.html

最近发表

热门文章

好文推荐

Java265.com

https://www.java265.com

站长统计|粤ICP备14097017号-3

Powered By Java265.com信息维护小组

使用手机扫描二维码

关注我们看更多资讯

java爱好者