Hystrix熔断

    它的作用是:当某个业务发生故障,通过断路器监控,向一个调用方返回一个错误相应,而不是长时间等待,避免了故障在分布式系统中的蔓延。

  •     服务熔断与降级

 熔断机制是应对雪崩效应的一种保护机制,当某个微服务不可用或长时间不响应,会进行服务降级,进而熔断该节点微服务的调用,快速返回错误的响应信息,当微服务恢复正常后 恢复调用。

 

@EnableCircuitBreaker
  • 建立正式方法及备用方法
@RequestMapping("/test")
@RestController
public class TestController {

    @RequestMapping("/get/{id}")
    @HystrixCommand(fallbackMethod = "getForBack")
    public String get(@PathVariable("id") String id) {
        System.out.println("服务端收到的id为:" + id);
        if (id.equals("2")) {
            throw new RuntimeException("报错");
        }
        return "服务端1";
    }

    public String getForBack(@PathVariable("id") String id) {
        return "回调方法-服务端1";
    }
}
  • 将所有服务都启动。可以发现id为2的时候,走了备用方法

 

  • 在上面样例上继续操作
  • 在service,接口提供包里加一个类,TestService就是feigin接口
@Component
public class FallBackFactory implements FallbackFactory<TestService> {
    @Override
    public TestService create(Throwable throwable) {
        return new TestService() {
            @Override
            public String get(String id) {
                return "接口没有调通";
            }
        };
    }
}
  • 在接口上添加fallback
@FeignClient(name = "PRODUCT", configuration = FeignClientConfig.class, fallbackFactory = FallBackFactory.class)
public interface TestService {

    @RequestMapping("/test/get/{id}")
    public String get(@PathVariable("id") String id);
}
  • 在消费端添加配置
feign:
  hystrix:
    enabled: true
  • 结束

服务提供方关掉之后,

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值