场景

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

https://blog.csdn.net/BADAO_LIUMANG_QIZHI/article/details/124948025

服务熔断

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

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

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

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

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

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

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

注:

博客:
https://blog.csdn.net/badao_liumang_qizhi
关注公众号
霸道的程序猿
获取编程相关电子书、教程推送与免费下载。

实现

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秒内进行高频次的传递负数参数,使其触发熔断机制,

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

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

 

 

posted on 2022-05-25 16:05  霸道流氓  阅读(186)  评论(0编辑  收藏  举报