spring cloud的版本不断演进,导致很多配置的配置方式不断改变,有时某个配置在一个版本里面默认是true,后边一升级默认成了false,这点让人有点不爽。
言归正传
0、所使用版本
spring cloud版本:Dalston.SR1
spring boot版本:1.5.4.RELEASE
步骤如下:
1、在配置文件中添加以下关键内容:
spring: cloud: loadbalancer: retry:# 据说ribbon重试默认已经开启 enabled: truezuul:# 重试必配,据说在Brixton.SR5版的spring cloud中该配置默认是true,结果在Dalston.SR1中看到的是false retryable: trueribbon:# ribbon重试超时时间 ConnectTimeout: 250# 建立连接后的超时时间 ReadTimeout: 1000# 对所有操作请求都进行重试 OkToRetryOnAllOperations: true# 切换实例的重试次数 MaxAutoRetriesNextServer: 2# 对当前实例的重试次数 MaxAutoRetries: 1 eureka: enable: true
注意:
如果想指定某个路径的重试的开启和关闭,可以配置zuul.routes.<route>.retryable的false和true
2、在pom中引入如下内容:
org.springframework.retry spring-retry
以支持:org.springframework.retry.support.RetryTemplate,进而初始化ribbon的重试策略,原因如下图源码所示,注意其中的@ConditionalOnClass
3、重试好像(尴尬脸)不会跨zone
完毕