为了账号安全,请及时绑定邮箱和手机立即绑定

『互联网架构』软件架构-深入理解Feign

标签:
Java

Feign是Netflix开发的声明式、模板化的HTTP客户端, Feign可以帮助我们更快捷、优雅地调用HTTP API。

(一)Feign的介绍

  1. Feign是一个声明式的http客户端,使用Feign可以实现声明式REST调用。spring cloud为Feign整合了Eureka,Ribbon,以提供服务发现及负载均衡等能力,同时整合了SpringMVC注解 。
  2. Feign默认使用SpringMVC注解提供契约来进行REST访问,例@RequestMapping,@PathVariable等 。
  3. 在之前的订单微服务中,调用用户微服务,我们使用的是RestTemplate.getForObject(), URL是我们自己拼接的字符串。如果参数较多的情况下,这种URL拼接参数的方式很低效,很不方便的。而Feign就解决了这些问题 。
  • 官方

  • Feign基本使用

加入Feign依赖,修改POM文件

创建一个Feign接口UserFeignClient,并在接口上面添加注解@FeignClient
启动类ConsumerOrderApplication增加@EnableFeignClients注解
见示例: 05-ms-consumer-order-feign

记住运行的时候一定要启动:eureka-server,都是依赖他来进行注册的。

  • Feign继承

这个就类似dubbo引用jar包的方式,但是不推荐使用这种,如果jar包在私服上发生变化,影响客户端的开发。

  1. Feign支持继承,使用继承可以将一些公共操作分组到一些父接口中,从而简化Feign的开发
  2. 抽取用户服务<05-ms-provider-user>的公共接口到新的项目中<05-ms-provider-user-api>,增加父接口UserService
  3. 在用户服务服务<05-ms-provider-user>和订单服务<05-ms-consumer-order-feign>里加入新项目的依赖

  1. 在订单服务里增加接口UserService的子接口RefactorUserService,并在子接口上加注解@FeignClient

源码:05-ms-consumer-order-feign

  • 源码分析:Ribbon的源码,直接去git下载我的源码就可以了。

PS:zookeeper是CP(一致性,容错),eureka是AP(高可用,容错),Feign是方便调用的框架,Ribbon是客户端的负载均衡。

点击查看更多内容
TA 点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
  • 推荐
  • 评论
  • 收藏
  • 共同学习,写下你的评论
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消