首先声明一点,这里的重试并不是报错以后的重试,而是负载均衡客户端发现远程请求实例不可到达后,去重试其他实例。
Table 1. ribbon重试配置
ribbon.OkToRetryOnAllOperations
false(`是否所有操作都重试`)
ribbon.MaxAutoRetriesNextServer
2(`重试负载均衡其他的实例最大重试次数,不包括首次server`)
ribbon.MaxAutoRetries
1(`同一台实例最大重试次数,不包括首次调用`)
spring.cloud.loadbalancer.retry.enabled
true(`重试机制开关`)
ribbon针对http的readTimeout和connectTimeCount直接用配置 ribbon.ReadTimeout和ribbon.ConnectTimeout是无效的。配置方式参考以下代码
@Bean
@LoadBalanced
RestTemplate restTemplate() {
    HttpComponentsClientHttpRequestFactory httpRequestFactory =  new HttpComponentsClientHttpRequestFactory();
    httpRequestFactory.setReadTimeout(5000);
    httpRequestFactory.setConnectTimeout(5000);
    return new RestTemplate(httpRequestFactory);
}
Table 2. zuul重试配置
zuul.retryable
true(`重试机制开关`)
ribbon.OkToRetryOnAllOperations
false(`是否所有操作都重试`)
ribbon.MaxAutoRetriesNextServer
2(`重试负载均衡其他的实例最大重试次数,不包括首次server`)
ribbon.MaxAutoRetries
1(`同一台实例最大重试次数,不包括首次调用`)
ribbon.ConnectTimeout
6000(`http建立socket超时时间`)
ribbon.ReadTimeout
6000(`http读取响应socket超时时间`)
hystrix.command.default.execution.isolation.thread.timeoutInMilliseconds
10000(断路器线程池超时时间,这个值一定要比ribbon超时时间长)
feign重试机制
feign默认是通过自己包下的Retryer进行重试配置,默认是5次
package feign;
import static java.util.concurrent.TimeUnit.SECONDS;
/**
 * Cloned for each invocation to {@link Client#execute(Request, feign.Request.Options)}.
 * Implementations may keep state to determine if retry operations should continue or not.
 */
public interface Retryer extends Cloneable {
  /**
   * if retry is permitted, return (possibly after sleeping). Otherwise propagate the exception.
   */
  void continueOrPropagate(RetryableException e);
  Retryer clone();
  public static class Default implements Retryer {
    private final int maxAttempts;
    private final long period;
    private final long maxPeriod;
    int attempt;
    long sleptForMillis;
    public Default() {
      this(100, SECONDS.toMillis(1), 5);
    }
    public Default(long period, long maxPeriod, int maxAttempts) {
      this.period = period;
      this.maxPeriod = maxPeriod;
      this.maxAttempts = maxAttempts;
      this.attempt = 1;
    }
feign取消重试
    @Bean
    Retryer feignRetryer() {
        return Retryer.NEVER_RETRY;
    }
feign请求超时设置
@Bean
Request.Options requestOptions(ConfigurableEnvironment env){
    int ribbonReadTimeout = env.getProperty("ribbon.ReadTimeout", int.class, 6000);
    int ribbonConnectionTimeout = env.getProperty("ribbon.ConnectTimeout", int.class, 3000);
    return new Request.Options(ribbonConnectionTimeout, ribbonReadTimeout);
}
Last updated 2017-05-18 23:39:30 CST
 
  
  
  
 
