Spring Cloud Feign

本文介绍了Spring Cloud Feign的基本概念,使用步骤,包括依赖引入、配置重试与异常处理,以及参数传递方式。重点讲解了Feign如何集成Ribbon实现负载均衡,并提到了Hystrix在容错中的作用。
摘要由CSDN通过智能技术生成


一、Feign是什么?

OpenFeign是Spring Cloud提供的一个声明式的伪Hltp客户端,它使得调用远程服务就像调用本地服务一样简单,只需要创建一个接口并添加一个注解即可,Nacos很好的兼容了OpenFeign,OpenFeign默认集成了Ribbon,
所以在Nacos下使用OpenFeign默认就实现了负载均衡的效果。

二、使用步骤

在这里插入图片描述

1.消费方导入依赖

<dependency>																																			
    <groupId>org.springframework.cloud</groupId>																																			
    <artifactId>spring-cloud-starter-openfeign</artifactId>																																			
</dependency>																																			

2.服务消费方的主程序启动类添加注解,开启@EnableFeignClients

@SpringBootApplication
@MapperScan("com.csqf.mapper")
@Import({
        Swagger2Config.class,
        ControllerExceptionAdvice.class,
})
@EnableFeignClients
public class springcloud_share_6002 {
    public static void main(String[] args) {
        SpringApplication.run(springcloud_share_6002.class,args);
    }

    @Bean
    @LoadBalanced
    public RestTemplate restTemplate(){
        return new RestTemplate();
    }
}

在这里插入图片描述

3.服务消费方 创建远程调用接口

@Service
@FeignClient("user-6001")
public interface UserFeignService {

    @GetMapping("/api/user/{id}")
    public R getUserNameById(@PathVariable("id") Integer id);
}

4.更改代码后测试

@RestController
@RequestMapping("/api/share")
public class ShareContoller {
    @Autowired
    private ShareServiceImpl shareService;
//    @Autowired
//    private RestTemplate restTemplate;
//    @Autowired
//    private DiscoveryClient discoveryClient;
    @Autowired
    private UserFeignService userFeignService;

    @GetMapping("/{id}")
    public R getShareById(@PathVariable("id") Integer id) {
        Share share = shareService.getShareById(id);
        R r = userFeignService.getUserNameById(share.getUserId());
        String s = r.getData().toString();
        ShareDto shareDto = new ShareDto();
        BeanUtils.copyProperties(share,shareDto);
        shareDto.setUserName(s);
        return new R(ResponseEnum.SUCCESS,shareDto);
    }
}

三、Feign相关

1.重试机制

  • 如果所有的重试完成 还是失败 要抛出 feign.RetryableException 异常
  • 重试 会产生接口的幂等性问题
    • 查询的接口 天生是幂等的
    • 增删改的处理 非幂等的
配置说明
hystrix.command.default.execution.isolation.thread.timeoutInMilliseconds断路器的超时时间需要大于ribbon的超时时间,不然不会触发重试。
hello-service.ribbon.ConnectTimeout请求连接的超时时间
hello-service.ribbon.ReadTimeout请求处理的超时时间
hello-service.ribbon.OkToRetryOnAllOperations是否对所有操作请求都进行重试
hello-service.ribbon.MaxAutoRetriesNextServer重试负载均衡其他的实例最大重试次数,不包括首次server

2 远程调用的时候出现异常的处理(ControllerExceptionAdvice)

    @ExceptionHandler(RetryableException.class)
    @ResponseBody
    public R doException(RetryableException ex){
        ex.printStackTrace();
        //  System.out.println("抛出未知异常");
        return new R(ResponseEnum.FEIGN_RETRY,null);
    }											

3.Feign的传递参数方式注意事项

  • 如果你传递的参数,比较复杂时,默认会采用POST的请求方式。
    传递单个参数时,推荐使用@PathVariable,如果传递的单个参数比较多,这里也可以采用@RequestParam,不要省略value属性

  • 传递对象信息时,统一采用json的方式,添加@RequestBody。Client接口必须采用@RequestMapping
    在这里插入图片描述
    在这里插入图片描述
    spring cloud项目使用feign的时候都会发现一个问题,就是get方式无法解析对象参数。其实feign是支持对象传递的,但是得是Map形式,而且不能为空,与spring在机制上不兼容,因此无法使用。

spring cloud在2.1.x版本中提供了@SpringQueryMap注解,可以传递对象参数,框架自动解析。
在这里插入图片描述

调用方feign接口只能是被调用方接口
public R f1(User user) 或 public R f1(@RequestBoby User user)参数 @RequstBoby 对象
public R f1(@SpringQueryMap User user)参数 对象

在这里插入图片描述

总结

  • Feign集成ribbon 和 resttemplate,简化 服务之间的调用
  • Feign是通过内置的Ribbon进行负载均衡,并通过HTTP去访问被调用方,所以Feign的重试,其实就是Ribbon的重试。另外,我们在实际工作中使用Feign,用到Hystrix,在这里就顺便说一下Hystrix的原理。举例说明下,假如在没有Hystrix的情况下,用户一个下单操作需要调用订单、支付、物流三个服务,如果其中物流Service因为种种问题不能提供服务,即便另外两个服务都好好的,整个下单操作也会因为物流Service而阻塞住,导致下单服务崩溃。而Hystrix为每个依赖的服务配置独立的线程池并进行隔离,假设下单服务有90个线程,没有Hystrix,则因为物流Service不能提供服务,不停地重试直到90个线程全卡死。而有了Hystrix,三个依赖的服务,每个30个线程,即便物流的30个全部阻塞了,也不影响另外两个服务的线程。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

jsxllht

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值