场景

SpringCloud中集成Hystrix实现服务降级(从实例入手):

​​SpringCloud中集成Hystrix实现服务降级(从实例入手)_霸道流氓气质的博客-

服务熔断

类比保险丝达到最大服务访问之后,直接拒绝访问,拉闸限电,然后调用服务降级的方法并返回友好提示。

服务的降级-进而熔断-恢复调用链路。

熔断机制是应对雪崩效应的一种微服务链路保护机制。当扇出链路的某个微服务出错不可用或者响应时间

太长时,会进行服务的降级,进而熔断该节点微服务的调用,快速返回错误的响应信息。

当检测到该节点微服务调用响应正常后,恢复调用链路。

在Spring Cloud框架中,熔断机制通过Hystrix实现。Hystrix会监控微服务之间调用的状况。

当失败的调用达到一定阈值,缺省是5秒内20次调用失败,就会启动熔断机制。熔断机制的注解是@HystrixCommand

注:

博客:​​霸道流氓气质的博客_-C#,架构之路,SpringBoot领域博主​​ 关注公众号
霸道的程序猿
获取编程相关电子书、教程推送与免费下载。

实现

1、在上面的基础上,在服务提供者8001的service新建业务方法模拟熔断的触发场景

@HystrixCommand(fallbackMethod = "paymentCircuitBreaker_fallback",commandProperties = {
@HystrixProperty(name = "circuitBreaker.enabled",value = "true"),// 是否开启断路器
@HystrixProperty(name = "circuitBreaker.requestVolumeThreshold",value = "10"),// 请求次数
@HystrixProperty(name = "circuitBreaker.sleepWindowInMilliseconds",value = "10000"), // 时间窗口期
@HystrixProperty(name = "circuitBreaker.errorThresholdPercentage",value = "60"),// 失败率达到多少后跳闸
})
public String paymentCircuitBreaker(@PathVariable("id") Integer id)
{
if(id < 0)
{
throw new RuntimeException("******id 不能负数");
}
String serialNumber = IdUtil.simpleUUID();

return Thread.currentThread().getName()+"\t"+"调用成功,流水号: " + serialNumber;
}
public String paymentCircuitBreaker_fallback(@PathVariable("id") Integer id)
{
return "id 不能负数,请稍后再试,/(ㄒoㄒ)/~~ id: " +id;
}

注意这里的注解的各个含义。

这个业务方法会根据传递的参数返回正常和异常的结果。

2、Controller层新建方法调用

@GetMapping("/payment/circuit/{id}")
public String paymentCircuitBreaker(@PathVariable("id") Integer id)
{
String result = paymentService.paymentCircuitBreaker(id);
log.info("****result: "+result);
return result;
}

3、然后调用该接口,在10秒内进行高频次的传递负数参数,使其触发熔断机制,

此时再接着传递正数参数,还是会提示不能为负数,因为此时已经熔断,稍等一会之后,

链路会进行恢复,正数返回正常的参数。

SpringCloud中集成Hystrix实现熔断(从实例入手)_链路