- 引入依赖:
<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方式请求其参数是对象时——服务端接口接收不到对象的情况;
此时有两种办法:一是将对象拆解出来,一个个传参数;原因:get原理其实是拼接的一个一个参数发送给服务端,然后映射到对象的属性值;所以如果feign 消费端中直接传一个对象服务端是接收不到的;
二是将服务端接口改成post方式结合@RequestBody即可传递对象参数: