OpenFeign 实践之 FeignClient 超时设置

简介: OpenFeign 实践之 FeignClient 超时设置

一、问题描述:


如果我们线上有一些同步请求的接口比如:


1、批量发邮件


2、一次执行上万的数据处理


3、同步调用支付接口


如果我们有以上的操作可能出现下面的异常


image.png


其实这里有两种解决方案:


  1. 由于被调用方处理的时间比较长, 调用方可以选择增加等待时间


  1. 修改被调用方的处理逻辑,优化设计。


  1. 修改调用放的处理逻辑,修改直接调用为,隐式调用。


问题不在发散,我就想做一条咸鱼,保证服务不报错,我们就直接改 feign 的等待时间即可


二、解决方法:


在解决方法的部分,我们还是先贴出部分已有的代码和逻辑,来回应一下当前的场景。


部分代码


1、Feign 接口定义如下:


@FeignClient(name = "payment-service", path = "/payment")
public interface PaymentFeign {
    @PostMapping("/create")
    PaymentVo create(@RequestBody @Validated PaymentDto paymentDto);
}


2、调用代码如下:


@Autowired
    private PaymentFeign paymentFeign;
    @GetMapping("/create")
    public OrderVo create(@Validated OrderDto orderDto) {
        log.info("uri:/order/create lang:{}", LocaleContextHolder.getLocale().getLanguage());
        // 忽略逻辑代码 N 行
        paymentFeign.create(paymentDto);
        log.info("uri:/order/create paymentFegin.create cost: {} ms", System.currentTimeMillis() - start);
        return orderVo;
    }


3、feign 超时配置


feign:
  client:
    config:
      default:
        # 日志级别
        loggerLevel: full
        # 超时设置 1.5 秒超时
        connectTimeout: 1500
        readTimeout: 1500
  # 断路器
  circuitbreaker:
    enabled: true


一句话概括上面的代码:我在 xxx/create 接口中调用了, /payment/create 且我设置了, feign 的超时时间为 1.5s。但是由于 /payment/create 调用过程中超时,返回了 TimeOut。


解决方案


方案一:


增加 feign 的默认超时时间,为 5s


feign:
  client:
    config:
      default:
        # 日志级别
        loggerLevel: full
        # 超时设置 5 秒超时
        connectTimeout: 5000
        readTimeout: 5000
  # 断路器
  circuitbreaker:
    enabled: true


方案二:


指定feign 接口的 contextId 设置当前 feign 的超时时间为 5s.


feign:
  client:
    config:
      default:
        # 日志级别
        loggerLevel: full
        # 超时设置
        connectTimeout: 1500
        readTimeout: 1500
      payment-core:
        connectTimeout: 5000
        readTimeout: 5000
  # 断路器
  circuitbreaker:
    enabled: true


PaymentFeign 设置上 contextId 属性


@FeignClient(name = "payment-service", contextId = "payment-core",  path = "/payment")
public interface PaymentFeign {
    @PostMapping("/create")
    PaymentVo create(@RequestBody @Validated PaymentDto paymentDto);
}


这样做,我们就可以减少影响,减少下游的影响。


三、总结:


还有一点我门需要注意,该配置不支持热更新,如果我们修改超时时间过后,需要重启服务。 如果我们不重启的,可以修改配置, 实现


feign.client.refresh-enabled=true


参考地址资料: spring-cloud-openfeign


相关文章
|
4月前
|
负载均衡
OpenFeign重试组件Retryer原理
该文章主要讲解了OpenFeign中的重试组件Retryer的工作原理及其实现细节。
OpenFeign重试组件Retryer原理
|
4月前
|
负载均衡 Java Spring
Ribbon的超时配置会覆盖OpenFeign的超时配置吗
该文章详细分析了OpenFeign与Ribbon之间的超时配置关系,解释了Ribbon如何覆盖OpenFeign的默认超时配置,并探讨了OpenFeign超时配置的动态修改方案。
|
7月前
|
Java Spring
Spring的@Retryable实现方法重试
`@Retryable`注解用于配置异常重试,参数包括:指定异常类型`value`,额外包含异常`include`,排除异常`exclude`,最大尝试次数`maxAttempts`和回退策略`backoff`。可选地,可以用`retryExceptions`列表替换`value`。当重试失败,可使用`@Recover`注解定义恢复逻辑。
78 1
|
7月前
|
Java Spring
spring cloud 通过feign请求动弹设置请求头heades
spring cloud 通过feign请求动弹设置请求头heades
377 0
|
Java 数据处理 Spring
Spring Cloud OpenFeign 超时与重试
今天给大家分享的是 `feign` 的超时与重试配置。
872 0
Spring Cloud OpenFeign 超时与重试
|
Java API 微服务
Spring Cloud Alibaba - 14 OpenFeign自定义配置 + 调用优化 + 超时时间
Spring Cloud Alibaba - 14 OpenFeign自定义配置 + 调用优化 + 超时时间
387 0
|
Java Spring
Spring Cloud学习 之 Spring Cloud Ribbon 重试机制及超时设置不生效
Spring Cloud学习 之 Spring Cloud Ribbon 重试机制及超时设置不生效
643 1
|
Java Spring
Spring Cloud中,如何解决Feign/Ribbon第一次请求失败的问题?
Spring Cloud中,Feign和Ribbon在整合了Hystrix后,可能会出现首次调用失败的问题,要如何解决该问题呢? 造成该问题的原因 Hystrix默认的超时时间是1秒,如果超过这个时间尚未响应,将会进入fallback代码。
2474 0
SpringCloud学习笔记(六)-Zuul及Feign的超时时间测试
SpringCloud学习笔记(六)-Zuul及Feign的超时时间测试
SpringCloud学习笔记(六)-Zuul及Feign的超时时间测试
|
负载均衡 Java 微服务
SpringCloud openFeign远程调用超时解决办法
SpringCloud openFeign远程调用超时解决办法
770 0