五分钟内反应回复,平均十分钟解决任何IT技术问题,按难度跟工作量收费!

(九十)java版spring cloud+spring boot+redis多租户社交电子商务平台-Feign对Hystrix的支持

IT 小兵 |浏览44次 |售价:0元 |联系博客主
收藏|2019/06/20 16:40

电子商务平台源码请加企鹅求求:三伍三六二四柒二五玖。如果Hystrix在classpath下,默认情况下将包括Feign与断路器的所有方法。返回一个com.netflix.hystrix.HystrixCommand去使用,允许你使用反应模式(调用.toObservable或.observe()或异步使用(.queue()))。要禁用Feign的Hystrix支持,设置feign.hystrix.enable=false。


要在每个客户端上禁用Hystrix支持,创建一个Feign.Builder并将scope设置为“prototype”,例如:

@Configuration
public class FooConfiguration {
    @Bean
    @Scope("prototype")
    public Feign.Builder feignBuilder() {
        return Feign.builder();
    }
}

 


Feign Hystrix Fallbacks (失败回退)


Hystrix支持失败回退的概念,当线路有错误是则执行默认代码路径,启用回退要给@FeignClient设置fallback属性来实现回退的类名。


编写一个实现类,实现Client接口

@Component
public 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属性

 


咨询/回复该博客即可获得 2 经验值,咨询/回复被采纳即可获得 2 经验值!
咨询/回复

验证码

  换一个
全部回答(0)
+1
 加载中...