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,整体的服务如下所示:

java feign定义接口 feign接口不需要实现_restful

2.2 RestTemplate

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

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

java feign定义接口 feign接口不需要实现_java feign定义接口_02

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

java feign定义接口 feign接口不需要实现_spring boot_03


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

java feign定义接口 feign接口不需要实现_java_04


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

java feign定义接口 feign接口不需要实现_spring cloud_05

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

java feign定义接口 feign接口不需要实现_spring cloud_06

java feign定义接口 feign接口不需要实现_java feign定义接口_07

2.3 Feign Client

1、导入依赖

java feign定义接口 feign接口不需要实现_java feign定义接口_08


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

java feign定义接口 feign接口不需要实现_java_09

3、定义Feign接口

java feign定义接口 feign接口不需要实现_restful_10

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

4、通过Feign客户端接口发送请求 注入Feign接口,可以直接调用接口中的方法(具体实现由Feign完成)即可发起请求。

java feign定义接口 feign接口不需要实现_spring boot_11

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

java feign定义接口 feign接口不需要实现_spring cloud_06

java feign定义接口 feign接口不需要实现_java feign定义接口_07

2.4 总结

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