SpringCloud视频教程:
https://ke.qq.com/course/2805647?tuin=a3e3fb1&from_uin=171851697&from=1000201007
个人博客纯净版
本文代码git地址 https://gitee.com/xmingtx/springcloud-lesson.git
Feign是自带断路器的,在D版本的Spring Cloud之后,它没有默认打开。需要在配置文件中配置打开它,在application.yml配置文件添加以下配置:
feign:
hystrix:
enabled: true
基于consumer-feign工程进行改造,只需要在HelloFeginClient接口的FeignClient注解中加上fallback的指定类就行了:
@FeignClient(value = "eureka-client-provider", fallback = HelloFeginFallback.class)
public interface HelloFeginClient {
@GetMapping("/hello")
String hello(@RequestParam(value = "name") String name);
}
HelloFeginFallback需要实现HelloFeginClient 接口,并注入到Ioc容器中,代码如下:
@Component
public class HelloFeginFallback implements HelloFeginClient {
@Override
public String hello(String name) {
return "hello," + name + ",sorry,error!";
}
}
启动四consumer-feign工程,浏览器打开http://localhost:8091/hello?name=xiaoming,注意此时eureka-client-provider工程没有启动,网页显示:
通过fegin客户端调用结果为:hello,xiaoming,sorry,error!
启动eureka-client-provider服务,再次访问,浏览器显示:
通过fegin客户端调用结果为:hello, xiaoming, 我是服务提供者:端口为:8080
这证明断路器起到作用了。
本文介绍了如何在Spring Cloud项目中使用Feign并启用Hystrix断路器。当依赖服务不可用时,断路器能够防止服务雪崩,确保系统的稳定性。通过在`application.yml`配置文件中开启断路器,并在FeignClient注解中指定fallback类,实现了服务调用的故障切换。实例展示了在eureka-client-provider未启动时,consumer-feign工程能够返回预设的错误信息。
452

被折叠的 条评论
为什么被折叠?



