场景 SpringCloud中集成Hystrix实现服务降级(从实例入手): SpringCloud中集成Hystrix实现服务降级(从实例入手)_霸道流氓气质的博客- 服务熔断 类比保险丝达到最大服务访问之后,直接拒绝
场景
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秒内进行高频次的传递负数参数,使其触发熔断机制,
此时再接着传递正数参数,还是会提示不能为负数,因为此时已经熔断,稍等一会之后,
链路会进行恢复,正数返回正常的参数。