feign+ribbon重试机制

feign的重试与ribbon存在冲突,spring在某个版本后默认关闭了feign自身的重试机制.

引入ribbon包后,默认会自动开启ribbon重试机制. 自己需要配置ribbon的超时时间,只有ribbon的超时时间小于hystrix的超时熔断时间时,才会进行重试.

(ribbon默认会对当前服务实例重试一次,然后对下一个服务实例重试一次)

注意:
默认情况下,GET方式请求无论是连接异常还是读取异常,都会进行重试;
非GET方式请求,只有连接异常时,才会进行重试.
不要启用ribbon的重试所有操作,即OkToRetryOnAllOperations不要配置true,因为这又涉及到了幂等性问题
Http幂等性理解、FeignClient和Ribbon重试机制深入理解

请求次数为:

MaxAutoRetries + MaxAutoRetriesNextServer + (MaxAutoRetries * MaxAutoRetriesNextServer )

如果想固定重新请求的次数,需要同时配置MaxAutoRetriesNextServer=0或者MaxAutoRetries=0

关闭请求重试将MaxAutoRetriesNextServer和MaxAutoRetries都等于0

ribbon:
  ReadTimeout: 3000
  ConnectTimeout: 3000
  MaxAutoRetries: 0
  MaxAutoRetriesNextServer: 0
  • 2
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值