1.Feign简介

Feign 是在 Ribbon 的基础上进行了一次改进,是一个使用起来更加方便的 HTTP 客户端。Ribbon 和 Feign 都是用于调用其他服务的,方式不同。Feign 则是在 Ribbon 的基础上进行了一次改进,采用接口的方式,将需要调用的其他服务的方法定义成抽象方法即可,不需要自己构建 http 请求。不过要注意的是抽象方法的注解、方法签名要和提供服务的方法完全一致。然后在上面添加注解即可 ,将需要调用的其他服务的方法定义成抽象方法即可, 不需要自己构建 http 请求。使得编写 客户端变得非常容易。

区别:

1.启动类使用的注解不同,Ribbon 用的是@RibbonClient,Feign 用的是@EnableFeignClients。

2.服务的指定位置不同,Ribbon 是在@RibbonClient 注解上声明,Feign 则是在定义抽象方法的接口中使用@FeignClient 声明和在启动类添加@EnableFeignClients实现启用。

3.调用方式不同,Ribbon 需要自己构建 http 请求,模拟 http 请求然后使用 RestTemplate 发送给其他服务,步骤相当繁琐.

微服务间通过feign接口调用时重试机制_客户端

2.openFeign和Feign的区别

1)Feign是Spring Cloud组件中一个轻量级RESTful的HTTP服务客户端,Feign内置了Ribbon,用来做客户端负载均衡,去调用服务注册中心的服务。Feign的使用方式是:使用Feign的注解定义接口,调用接口,就可以调用服务注册中心的服务。

1 <dependency>
2     <groupId>org.springframework.cloud</groupId>
3     <artifactId>spring-cloud-starter-feign</artifactId>
4 </dependency>

2)OpenFeign目前是Spring Cloud 二级子项目。而Feign指的是Netflix下的Feign,现在我们学习的是OpenFeign,是Spring提供的。

并且OpenFeign是Spring Cloud在Feign的基础上支持了SpringMVC的注解,如@RequestMapping等等。OpenFeign的@FeignClient可以解析SpringMVC的@RequestMapping注解下的接口,并通过动态代理的方式产生实现类,实现类中.

1 <dependency>
2     <groupId>org.springframework.cloud</groupId>
3     <artifactId>spring-cloud-starter-openfeign</artifactId>
4 </dependency>

3.feign实践

第一步:在服务消费方sca-consumer,添加项目依赖(SpringCloud团队基于OpenFeign研发了starter),代码参考上面:

微服务间通过feign接口调用时重试机制_微服务_02

第二步:在启动类上添加@EnableFeignClients注解,代码如下: 

微服务间通过feign接口调用时重试机制_微服务_03

第三步:定义Http请求API,基于此API借助OpenFeign访问远端服务,代码如下: 

其中,@FeignClient描述的接口底层会为其创建实现类。

微服务间通过feign接口调用时重试机制_微服务架构_04

 fallbackFactory=后备工厂.class解释:

当我们在进行远程服务调用时,假如调用的服务突然不可用了或者调用过程超时了,怎么办呢?一般服务消费端会给出具体的容错方案,

用于定义服务调用超时,网络阻塞等现象发生时。一种应对措施或处理机制,参考ruoyi.vip官网

接口:

微服务间通过feign接口调用时重试机制_微服务架构_05

工厂类:

 

微服务间通过feign接口调用时重试机制_抽象方法_06

 第四步:所以我们可以模仿他,写一个自己需要的FallbackFactory

微服务间通过feign接口调用时重试机制_微服务_07

微服务间通过feign接口调用时重试机制_微服务架构_08

feign:
  hystrix:
    enabled: true   #默认为flase 
feign的Hystrix支持默认关闭,需要手动设置启动feign方式调用时的服务中断处理机制。不然会导致fallbackFactory失效,

 第四步:创建 消费方控制层Controller中并添加feign访问,代码如下:

微服务间通过feign接口调用时重试机制_抽象方法_09

 4. 测试

微服务间通过feign接口调用时重试机制_抽象方法_10

当我们给提供方加一个睡眠时(模仿网络中的阻塞)feign会有一个默认超时的时间。

微服务间通过feign接口调用时重试机制_spring_11

 

微服务间通过feign接口调用时重试机制_微服务_12

 这时,会把错误发送给维护人员。因为没有定义错误信息返回所以为null

微服务间通过feign接口调用时重试机制_微服务架构_13