Hystrix熔断限流

Hystrix是熔断限流组件,与之相对应的组件有sentinel、Resilience4j等。Hystrix主要包含Hystrix Command、Hystrix ThreadPool、Hystrix Circuit Breaker。

Hystrix Command是一个封装了服务调用逻辑的对象,它可以通过注解(@HystrixCommand)或继承的方式来定义,并提供了两个重要的方法:run()和fallback()。run()方法表示正常的服务调用逻辑,fallback()方法表示异常或超时时的备选逻辑。

Hystrix ThreadPool是一个为Hystrix Command提供线程池资源的对象,它可以根据配置文件或参数指定线程池的大小、队列的长度、拒绝策略等信息。Hystrix ThreadPool可以按照不同的维度来划分,比如服务名称、功能模块、业务场景等,从而实现资源的隔离和控制。

Hystrix Circuit Breaker是一个实现熔断器模式的对象,它可以根据配置文件或参数指定熔断器的状态、触发条件、恢复策略等信息。熔断器有三种状态:关闭(Closed)、打开(Open)和半开(Half-Open)。关闭状态表示正常运行,打开状态表示熔断触发,半开状态表示尝试恢复。熔断器的触发条件一般是在一定时间窗口内,失败率或超时率超过一定阈值。熔断器的恢复策略一般是在一定时间间隔后,尝试发送少量请求,如果成功则恢复关闭状态,如果失败则继续打开状态。

服务之间的调用在加入Hystrix Command时,具体流程如下:

1、当一个服务需要调用另一个服务时,它会创建一个Hystrix Command对象,并根据配置文件或参数指定该对象所属的线程池、熔断器、超时时间等信息。

2、然后Hystrix Command对象会向Hystrix ThreadPool对象请求一个线程资源,并在该线程上执行run()方法,表示正常的服务调用逻辑。

3、如果run()方法在指定的超时时间内返回了正常的结果,那么Hystrix Command对象会将该结果返回给服务,并释放线程资源,并向Hystrix Circuit Breaker对象报告成功信息。

4、如果run()方法在指定的超时时间内没有返回结果,或者抛出了异常,那么Hystrix Command对象会执行fallback()方法,表示异常或超时时的备选逻辑,该结果返回给服务,并释放线程资源,同时向Hystrix Circuit Breaker对象报告失败信息。

5、如果fallback()方法也没有返回结果,或者抛出了异常,那么Hystrix Command对象会抛出一个HystrixRuntimeException异常,表示服务调用失败,并释放线程资源,同时向Hystrix Circuit Breaker对象报告失败信息。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值