电子商务平台源码请加企鹅求求:三五三六二四七二五九。若是Hystrix在classpath下,默认状况下将包括Feign与断路器的全部方法。返回一个com.netflix.hystrix.HystrixCommand去使用,容许你使用反应模式(调用.toObservable或.observe()或异步使用(.queue()))。要禁用Feign的Hystrix支持,设置feign.hystrix.enable=false。bash
要在每一个客户端上禁用Hystrix支持,建立一个Feign.Builder并将scope设置为“prototype”,例如:app
@Configuration
public class FooConfiguration {
@Bean
@Scope("prototype")
public Feign.Builder feignBuilder() {
return Feign.builder();
}
}
复制代码
Feign Hystrix Fallbacks (失败回退)异步
Hystrix支持失败回退的概念,当线路有错误是则执行默认代码路径,启用回退要给@FeignClient设置fallback属性来实现回退的类名。ide
编写一个实现类,实现Client接口ui
@Component
public class MenuClientFallback implements MenuClient {
@Override
public ResponseResult saveOrUpdateMenu(MenuModel menuModel) {
System.out.println("调用服务失败");
return new ResponseResult("-1", "调用服务失败");
}
}
复制代码
@FeignClient注解加上fallback属性,fallback属性的值就是实现类.classspa
@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.net
若是须要访问致使回退触发的缘由,能够在@FeginClient中使用fallbackFactory属性prototype