Spring Cloud 实战四:重试机制配置

上一篇写到,如何配置超时。在请求某个服务节点时,请求失败(如:请求超时、连接超时、服务宕机等,但并不是服务器报错),这时可以通过配置重试机制,重新请求其他服务。

首先引入依赖:

<dependency>
    <groupId>org.springframework.retry</groupId>
    <artifactId>spring-retry</artifactId>
</dependency>

1、rest+ribbon:重试机制配置

spring:
  application:
    name: client
  cloud:
   loadbalancer:
      retry:
        enabled: true
ribbon:
 # 同一实例最大重试次数,不包括首次调用
  MaxAutoRetries: 1
 # 重试其他实例的最大重试次数,不包括首次所选的server
  MaxAutoRetriesNextServer: 2
 # 是否所有操作都进行重试
  OkToRetryOnAllOperations: true

2、由于服务service-user 端口9001 调用接口中进行了Thread.sleep(120000L);所以请求超时之后,重试机制对9002端口进行了请求。

等待响应中:



最后请求结果,通过9002完成响应:



2、feign:重试机制配置

相关配置介绍

配置说明
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
hello-service.ribbon.MaxAutoRetries同一台实例最大重试次数,不包括首次调用

添加以下配置即可

全局配置

# feign重试机制
ribbon:
    MaxAutoRetries: 1
    MaxAutoRetriesNextServer: 2
    OkToRetryOnAllOperations: true

局部配置:

# feign重试机制
SERVICE-USER:
  ribbon:
    MaxAutoRetries: 1
    MaxAutoRetriesNextServer: 2
    OkToRetryOnAllOperations: true

最后:github地址:https://github.com/houxi1234/demo.git

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值