内容简介:Feign是Netflix开发的声明式、模板化的HTTP客户端, Feign可以帮助我们更快捷、优雅地调用HTTP API。源码:https://github.com/limingios/netFuture/tree/master/源码/『互联网架构』软件架构-深入理解Ribbon(93)/
Feign是Netflix开发的声明式、模板化的HTTP客户端, Feign可以帮助我们更快捷、优雅地调用HTTP API。
源码:https://github.com/limingios/netFuture/tree/master/源码/『互联网架构』软件架构-深入理解Ribbon(93)/
(一)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:dubbo是CP(一致性,容错),eureka是AP(高可用,容错),Feign是方便调用的框架,Ribbon是客户端的负载均衡。
>>原创文章,欢迎转载。转载请注明:转载自,谢谢!>>原文链接地址:上一篇:已是最新文章
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网
猜你喜欢:- 『互联网架构』软件架构-深入理解Ribbon(93)
- 步步深入:MySQL架构总览
- 深入 Nginx 之架构篇
- 《深入Linux内核架构》摘要
- [译] 深入理解 HBase 架构
- PaddlePaddle核心架构深入解读
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。