当前位置 : 主页 > 编程语言 > java >

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

来源:互联网 收集:自由互联 发布时间:2023-03-22
场景 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秒内进行高频次的传递负数参数,使其触发熔断机制,

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

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

SpringCloud中集成Hystrix实现熔断(从实例入手)_java

网友评论