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 发送给其他服务,步骤相当繁琐.
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),代码参考上面:
第二步:在启动类上添加@EnableFeignClients注解,代码如下:
第三步:定义Http请求API,基于此API借助OpenFeign访问远端服务,代码如下:
其中,@FeignClient描述的接口底层会为其创建实现类。
fallbackFactory=后备工厂.class解释:
当我们在进行远程服务调用时,假如调用的服务突然不可用了或者调用过程超时了,怎么办呢?一般服务消费端会给出具体的容错方案,
用于定义服务调用超时,网络阻塞等现象发生时。一种应对措施或处理机制,参考ruoyi.vip官网
接口:
工厂类:
第四步:所以我们可以模仿他,写一个自己需要的FallbackFactory
feign:
hystrix:
enabled: true #默认为flase
feign的Hystrix支持默认关闭,需要手动设置启动feign方式调用时的服务中断处理机制。不然会导致fallbackFactory失效,
第四步:创建 消费方控制层Controller中并添加feign访问,代码如下:
4. 测试
当我们给提供方加一个睡眠时(模仿网络中的阻塞)feign会有一个默认超时的时间。
这时,会把错误发送给维护人员。因为没有定义错误信息返回所以为null