springCloud配置Feign客户端及熔断器Hytrix(踩坑)

  • 引入依赖:
<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-openfeign</artifactId>
</dependency>
  • 在启动类上加入@EnbaleFeignClients
  • 在配置文件中加入以下配置开启feign的hytrix功能(默认是关闭的,注意:这个配置是单独一级的,不能配置在spring.cloud下面
feign:
  hystrix:
    enabled: true
  • 新建一个FeignClient接口以调用其它服务:
@FeignClient(value="tzg-service-business",fallback = BusinessHystric.class )//value表示要调用的服务名,fallback表示熔断处理类
public interface BusinessMirco {
    //表示要掉用的服务的api,value和该api的url保持一致,特别注意要有@RequestParam,否则会出错!
    @GetMapping(value =  "/" + GlobalConfigVar.VERSION +"/business/school/get_list")
    MsgResponse<String> getList(@RequestParam GetSchoolListParam param);

}
  • 新建一个熔断处理类(要继承FeignClient接口,并注入spring):
@Component
public class BusinessHystric implements BusinessMirco {
    //feign接口的具体熔断方法
    @Override
    public MsgResponse getList(GetSchoolListParam param) {
        return new MsgResponse().failure(-1,"服务器走神了");
    }

}
  • 再写个测试controller方法
@GetMapping("/testFeign")
public Object testFeign(){
    GetSchoolListParam listParam=new GetSchoolListParam();
    listParam.setCity_id(1);
    return  business.getList(listParam);//business为BusinessMirco实例;
}
  • 测试:启动本服务,调用的服务不开启

2019/07/26追加:在实际使用中咱们可能碰到使用Get方式请求其参数是对象时——服务端接口接收不到对象的状况;spring

此时有两种办法:一是将对象拆解出来,一个个传参数;缘由:get原理实际上是拼接的一个一个参数发送给服务端,而后映射到对象的属性值;因此若是feign                              消费端中直接传一个对象服务端是接收不到的;api

                          二是将服务端接口改为post方式结合@RequestBody便可传递对象参数:服务器

相关文章
相关标签/搜索