分布式系统问题
往往分布式系统结构中的应用程序,互相存在一定的依赖关系,每个依赖之间在某些情况将不可避免的失败,容易造成系统的崩溃。
服务雪崩
多个微服务之间调用的时候,假设微服务A调用微服务B和微服务C,微服务B和微服务C又调用了其他的微服务,这就是所谓的“扇出”。如果扇出的链路上某个微服务的响应时间过长或者不可用,对位服务A的调用就会占用越来越多的系统资源,进而引起系统崩溃,所谓的“雪崩效应”。
对于高流浪的应用来说,单一的后端依赖可能会导致所有服务器上的所有资源在几秒钟内饱和。比失败更糟糕的是,这些应用程序还可能导致服务之间的迟增高,备份队列,线程和其他系统资源紧张,导致整个系统发生更多的级联故障。这些都表示需要对故障和延迟进行隔离和管理,以便单个依赖关系的失败,不能取消整个应用程序或系统,所以,通常当你发现一个模块下的某个实例失败后,这时候这个模块一栏还会接收流量,然后这个有问题的模块还调用了其他的模块,这样就会发生级联故障,或者叫雪崩。
Hystrix
Hystrix是一个用于处理分布式系统的延迟和容错的开源库,在分布式系统中,许多依赖不可避免的会调用失败,比如超时和异常,Hystrix能够保证在一个依赖出问题的情况下,不会导致整体服务失败,避免级联故障,以提高分布式系统的弹性。
“断路器”本身是一种开关装置,当某个服务单元发生故障之后,通过断路器的故障监控(类似熔断保险丝),==向调用方返回一个符合预期的,可处理的备用响应(FallBack),而不是长时间的等待或者抛出调用方法无法处理的异常,==这样保证了服务的线程不会因为被长时间和不必要的占用,从而避免了故障在分布式系统的蔓延,乃至雪崩。
功能:服务降级、服务熔断、接近实时的监控
官网资料:传送门
注:目前已官宣停更发布新版本,不再接受合并请求,只会被动修复bug
配置
主启动类添加注解:@EnableCircuitBreake(或@EnableHystrix 后者继承了@EnableCircuitBreake)
Maven
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-hystrix</artifactId>
</dependency>
YML
如果为消费者Feign
feign:
hystrix:
enabled: true
服务降级
FallBack:当遇到程序运行异常、超时、服务熔断触发服务降级、线程池/信号量也会导致服务降级时,返回备用方案,如返回服务器忙,请稍后再试,不让客户端等待,返回一个友好提示。
需要在业务类上添加注解:@HystrixCommand
一旦调用服务方式失败并抛出了错误信息后,会自动调用@HystrixCommand注解中fallbackMethod指向的方法。
/**
*
* @author zhangminjie
* @create 2020-07-06 11:30
**/
@RestController
@Slf4j
//@DefaultProperties(defaultFallback = "payment_Global_FallbackMethod")
public class OrderController {
@Resource
private PaymentHystrixService paymentHystrixService;
/**
* 正常访问
*
* @param id
* @return
*/
@GetMapping("/consumer/hystrix/ok/{id}")
public String paymentInfo_OK(@PathVariable("id") Integer id) {
String result = paymentHystrixService.paymentInfo_OK(id);
log.info("*****result:" + result);
return result;
}
/**
* 超时访问
*
* @param id
* @return
*/
@GetMapping("/consumer/hystrix/timeout/{id}")
//@HystrixCommand(fallbackMethod = "consumer_TimeOut_fallback",commandProperties = {
// @HystrixProperty(name = "execution.isolation.thread.timeoutInMilliseconds", value = "80000")
//})
//@HystrixCommand
public String paymentInfo_TimeOut(@PathVariable("id") Integer id) {
String result = paymentHystrixService.paymentInfo_TimeOut(id);
log.info("*****result:" + result);
return result;
}
public String consumer_TimeOut_fallback(@PathVariable("id") Integer id){
return "我是消费者80,对方支付系统繁忙请10秒种后再试或者自己运行出错请检查自己,o(╥﹏╥)o";
}
/**
* 全局fallback
*
* @return
*