Feign是Netflix开发的声明式、模板化的HTTP客户端, Feign可以帮助我们更快捷、优雅地调用HTTP API。
(一)Feign的介绍
- Feign是一个声明式的http客户端,使用Feign可以实现声明式REST调用。spring cloud为Feign整合了Eureka,Ribbon,以提供服务发现及负载均衡等能力,同时整合了SpringMVC注解 。
- Feign默认使用SpringMVC注解提供契约来进行REST访问,例@RequestMapping,@PathVariable等 。
- 在之前的订单微服务中,调用用户微服务,我们使用的是RestTemplate.getForObject(), URL是我们自己拼接的字符串。如果参数较多的情况下,这种URL拼接参数的方式很低效,很不方便的。而Feign就解决了这些问题 。
- 官方
- Feign基本使用
加入Feign依赖,修改POM文件
创建一个Feign接口UserFeignClient,并在接口上面添加注解@FeignClient 启动类ConsumerOrderApplication增加@EnableFeignClients注解 见示例: 05-ms-consumer-order-feign
记住运行的时候一定要启动:eureka-server,都是依赖他来进行注册的。
- Feign继承
这个就类似dubbo引用jar包的方式,但是不推荐使用这种,如果jar包在私服上发生变化,影响客户端的开发。
- Feign支持继承,使用继承可以将一些公共操作分组到一些父接口中,从而简化Feign的开发
- 抽取用户服务<05-ms-provider-user>的公共接口到新的项目中<05-ms-provider-user-api>,增加父接口UserService
- 在用户服务服务<05-ms-provider-user>和订单服务<05-ms-consumer-order-feign>里加入新项目的依赖
- 在订单服务里增加接口UserService的子接口RefactorUserService,并在子接口上加注解@FeignClient
源码:05-ms-consumer-order-feign
- 源码分析:Ribbon的源码,直接去git下载我的源码就可以了。
PS:zookeeper是CP(一致性,容错),eureka是AP(高可用,容错),Feign是方便调用的框架,Ribbon是客户端的负载均衡。