为了账号安全,请及时绑定邮箱和手机立即绑定

Spring Cloud OpenFeign 超时与重试

标签:
Spring Cloud

今天给大家分享的是 feign 的超时与重试配置。

超时

feign:
  client:
    config:
      default:
        connectTimeout: 1000
        readTimeout: 1000

需要注意以下几点:

1、连接超时 (connectTimeout) 和 读取超时 (readTimeout) 同时配置时,才会生效。

2、超时单位为毫秒。

3、可根据服务名称单独定义超时。

比如, provider-get 服务提供的是查询接口,超时时间可以设置短一些:

feign:
  client:
    config:
      provider-get:
        connectTimeout: 1000
        readTimeout: 6000

而, provider-post 服务提供的是数据处理接口,超时时间可以设置长一些:

feign:
  client:
    config:
      provider-post:
        connectTimeout: 1000
        readTimeout: 20000

重试

实现 feign.Retryer 接口

public class MyRetryer implements Retryer {
    @Override
    public void continueOrPropagate(RetryableException e) {
        throw e;
    }

    @Override
    public Retryer clone() {
        return new Default(100, TimeUnit.SECONDS.toMillis(1), 5);
    }
}

三个参数的理解:

  • period:周期,重试间隔时间
  • maxPeriod:最大周期,重试间隔时间按照一定的规则逐渐增大,但不能超过最大周期
  • maxAttempts:最大尝试次数,重试次数

之后,我们可以进行配置:

feign:
  client:
    config:
      default:
        retryer: com.fengwenyi.springclouddemo.demospringcloudfeignsentinel.consumerservice.MyRetryer

希望今天的分享能够在工作中帮助到你。

点击查看更多内容
TA 点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
  • 推荐
  • 评论
  • 收藏
  • 共同学习,写下你的评论
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消