A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

如果Hystrix在classpath下,默认情况下将包括Feign与断路器的所有方法。返回一个com.netflix.hystrix.HystrixCommand去使用,允许你使用反应模式(调用.toObservable或.observe()或异步使用(.queue()))。要禁用Feign的Hystrix支持,设置feign.hystrix.enable=false。
需要JAVA Spring Cloud大型企业分布式微服务云构建的B2B2C电子商务平台源码
要在每个客户端上禁用Hystrix支持,创建一个Feign.Builder并将scope设置为“prototype”,例如:
@Configurationpublic class FooConfiguration {    @Bean    @Scope("prototype")    public Feign.Builder feignBuilder() {        return Feign.builder();    }}
Feign Hystrix Fallbacks (失败回退)
Hystrix支持失败回退的概念,当线路有错误是则执行默认代码路径,启用回退要给@FeignClient设置fallback属性来实现回退的类名。
编写一个实现类,实现Client接口
@Componentpublic class MenuClientFallback implements MenuClient {    @Override    public ResponseResult saveOrUpdateMenu(MenuModel menuModel) {        System.out.println("调用服务失败");        return new ResponseResult("-1", "调用服务失败");    }}
@FeignClient注解加上fallback属性,fallback属性的值就是实现类.class
@FeignClient(name = "WishfulCloud-Authority-Service", fallback=MenuClientFallback.class)public interface MenuClient {    @RequestMapping(value = "/menu/saveOrUpdateMenu", method = RequestMethod.POST)    public ResponseResult saveOrUpdateMenu(@RequestBody MenuModel menuModel);}
fallbackFactory
如果需要访问导致回退触发的原因,可以在@FeginClient中使用fallbackFactory属性
java B2B2C springmvc mybatis多租户电子商城系统

1 个回复

倒序浏览
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马