微服务003基于Feign的远程服务调用

发布时间:2022-07-05 发布网站:脚本宝典
脚本宝典收集整理的这篇文章主要介绍了微服务003基于Feign的远程服务调用脚本宝典觉得挺不错的,现在分享给大家,也给大家做个参考。

1.Feign简介

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

区别F1a;

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

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

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

微服务003基于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),代码参考上面:

微服务003基于Feign的远程服务调用

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

微服务003基于Feign的远程服务调用

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

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

微服务003基于Feign的远程服务调用

 fallbackFactory=后备工厂.class解释:

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

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

接口:

微服务003基于Feign的远程服务调用

工厂类:

 

微服务003基于Feign的远程服务调用

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

微服务003基于Feign的远程服务调用

微服务003基于Feign的远程服务调用

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

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

微服务003基于Feign的远程服务调用

 4. 测试

微服务003基于Feign的远程服务调用

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

微服务003基于Feign的远程服务调用

 

微服务003基于Feign的远程服务调用

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

微服务003基于Feign的远程服务调用

脚本宝典总结

以上是脚本宝典为你收集整理的微服务003基于Feign的远程服务调用全部内容,希望文章能够帮你解决微服务003基于Feign的远程服务调用所遇到的问题。

如果觉得脚本宝典网站内容还不错,欢迎将脚本宝典推荐好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。