Feign入门篇

举报
李子捌 发表于 2021/11/09 09:12:25 2021/11/09
【摘要】 1、简介Feign是一个REST客户端库,它通过接口驱动的方式来定义REST客户端。Spring Cloud Netflix体系中的Eureka服务注册中心客户端支持Ribbon客户端负载均衡器,而Feign本质上是Ribbon的包装,其内部是通过Ribbon来进行服务查找和负载均衡。在Spring Cloud Netflix体系中,我们通常会通过以下两种方式进行服务通信:支持负载均衡的Re...

1、简介

Feign是一个REST客户端库,它通过接口驱动的方式来定义REST客户端。Spring Cloud Netflix体系中的Eureka服务注册中心客户端支持Ribbon客户端负载均衡器,而Feign本质上是Ribbon的包装,其内部是通过Ribbon来进行服务查找和负载均衡。

在Spring Cloud Netflix体系中,我们通常会通过以下两种方式进行服务通信:

  1. 支持负载均衡的RestTemplate
  2. Feign生成的客户端接口

两种方式都是通过Ribbon进行服务查找,然后更加负载均衡策略选择服务进行服务通信,具体使用那种方式看个人爱好(小捌觉得Feign客户端接口这种方式,在代码上稍显复杂,但是更好管理)。


关于Feign的一点小知识:

大家经常听到有人说OpenFeign,有人说Feign,给人一种好像是两个东西的错觉。其实是因为Feign本身也是Netflix的开源项目,后面独立出来单独做了开源项目,改名为OpenFeign。这种情况其实很常见,比如鸿蒙-HarmonyOS就有Open HarmonyOS。


2、正文

正式开始Feign的学习之前,大家需要对微服务有一定的认识,关于这些知识点可以查看本专栏的往期文章,入门微服务、Eureka相关知识,并且搭建一个Eureka服务和客户端之后在来学习Feign。


2.1 服务搭建

搭建一个Eureka Server用于服务注册发现,此外准备两个相同的服务提供者SERVER和一个服务消费者CONSUMER,整体的服务如下所示:

2.2 RestTemplate

由于Feign和RestTemplate一样如果需要进行查找服务,都是通过集成Ribbon来实现的,所以这里向看在上面这种微服务架构中,如何通过RestTemplate来消费服务。这里贴出的服务端代码,在后面的Feign中是相同的,后面将不会再贴出。


1、服务提供者Server-01暴露REST端点:

2、服务提供者Server-02暴露REST端点:


3、声明RestTemplate bean,并且添加注解@LoadBalanced,这个注解会告诉Spring Boot这个RestTemplate需要具有通过Ribbon查找服务的能力,我这里因为演示所以在启动类中声明。


4、服务消费者Consumer通过RestTemplate消费服务代码:

这里服务提供者有两个,我们借助Ribbon和Eureka客户端可以实现服务的发现和负载均衡,注意服务地址不再硬编码,而是编写成服务提供者注册在Eureka上的服务名称server(不区分大小写)。

5、通过任意Http客户端请求Consumer提供的/consumer端点,不断刷新请求,可以看到RestTemplate 会依次轮训Server-01和Server-02

2.3 Feign Client

1、导入依赖


2、添加配置类启动Feign Client,可以直接在启动类上配置

3、定义Feign接口

这个接口定义完成,不需要实现类。在Spring boot运行时,当Feign发现了这个接口,Feign会自动创建一个实现类并将其暴露为Spring应用上下文中的bean


4、通过Feign客户端接口发送请求

注入Feign接口,可以直接调用接口中的方法(具体实现由Feign完成)即可发起请求。

5、通过任意Http客户端请求Consumer提供的/consumer端点,不断刷新请求,可以看到Feign Client会依次轮训Server-01和Server-02

2.4 总结

这篇文章入门了Feign,也顺带讲了下RestTemplate的简单使用。需要注意的是Fegin它并不负责解析服务名、负载均衡,这些都是其集成的Ribbon实现的。Feign可以替代RestTemplate,相比之下代码的可读性确实增强了,但是整体性能是有些许下降的。

【版权声明】本文为华为云社区用户原创内容,转载时必须标注文章的来源(华为云社区)、文章链接、文章作者等基本信息, 否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。