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对象报告失败信息。