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

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

  • 26
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 3
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值