介绍
Feign中对 Hystrix 有依赖关系。Feign只是一个便利的rest框架,简化调用,最后还是通过ribbon在注册服务器中找到服务实例,然后对请求进行分配。
使用
1、REST API 客户端
一般我们将REST API与项目通用的一些类统一存放在api客户端
FeignClient中内容与微服务提供者(provider)的Controller接口内容一样,只是将注解替换为@FeginClient
:
/**
* value中为微服务名称
*/
@FeignClient(value = "MICROSERVICECLOUD-DEPT")
public interface DeptClientService {
@PostMapping(value = "/dept/add")
boolean add(@RequestBody Dept dept);
@GetMapping(value = "/dept/get/{id}")
Dept get(@PathVariable("id") Long id);
@GetMapping(value = "/dept/list")
List<Dept> list();
@GetMapping(value = "/hello")
String index(@RequestParam("name") String name);
@GetMapping(value = "/dept/discovery")
Object discovery();
}
2、服务消费者
服务消费者的主启动类添加@EnableFeignClients
注解
controller中直接注入feignclient的实例即可:
@Autowired
private DeptClientService deptService;
@PostMapping(value = "consumer/dept/add")
public boolean add(Dept dept) {
return deptService.add(dept);
}
坑
1、@RequestParam
使用@RequestParam
修饰参数时,第一个参数必须指定非空,否则编译不通过,如下:
@GetMapping(value = "/hello")
String index(@RequestParam String name);
Caused by: java.lang.IllegalStateException: RequestParam.value() was empty on parameter 0
at feign.Util.checkState(Util.java:128) ~[feign-core-9.5.0.jar:na]
at org.springframework.cloud.netflix.feign.annotation.RequestParamParameterProcessor.processArgument(RequestParamParameterProcessor.java:63) ~[spring-cloud-netflix-core-1.3.1.RELEASE.jar:1.3.1.RELEASE]
正确写法应该是:
@GetMapping(value = "/hello")
String index(@RequestParam("name") String name);