什么是Feign
- Feign 是声明式的web service客户端,它让微服务之间的调用变得更加简单了
- SpringCloud集成了Ribbon和Eureka,可在使用Feign时提供负载均衡的http客户端
- 使用起来也比ribbon方便很多,只需要创建接口,然后使用注解
@FeignClient("服务名")
即可
Feign的用途
- 因为在实际开发中,由于对服务依赖的调用可能不止一处,往往一个接口会被多处调用,所以通常都会针对每个微服务自行封装一些客户端类来包装这些依赖服务的调用,Feign在此基础上进行了进一步的封装,由他来帮助我们定义和实现依赖服务接口的定义
- 在Feign的是线下,我们只需要创建一个接口并使用注解的方式来装配它
@FeignClient("服务名")
,即可完成对服务提供方的接口绑定,简化了Ribbon自动封装服务调用客户端的开发量
例如:我们在service-a中创建一个SERVICE-OBJECT-A服务
@RestController
public class HelloController {
@RequestMapping("/hello")
public String hello() {
return "hello world";
}
}
在另一个service-b中调用服务:
@Component
@FeignClient("SERVICE-OBJECT-A")
public interface ServiceAFeignClient {
@RequestMapping("/hello")
public String hello();
}
这样就实现了接口的绑定,就相当于service-a的HelloController是service-b的ServiceAFeignClient接口的实现,然后就可以调用service-b的ServiceAFeignClient接口来调用服务了:
@RestController
public class HelloController {
@Autowired
ServiceAFeignClient serviceAFeignClient;
@RequestMapping("/call")
public String call() {
String result = serviceAFeignClient.hello();
return "b访问了a的hello(),返回的结果为" + result;
}
}
这就利用Feign实现了一次服务的调用
Feign与Ribbon的关系
- Feign集成了Ribbon
- Feign利用了Ribbon维护了服务列表信息,并且通过轮询的方式实现了客户端的负载均衡,而与Ribbon不同的是,通过Feign只需要定义服务绑定接口且以声明式的方法,更加简单的实现了服务的调用