Spring Cloud学习 之 Spring Cloud Ribbon 重试机制及超时设置不生效

简介: Spring Cloud学习 之 Spring Cloud Ribbon 重试机制及超时设置不生效

今天测了一下Ribbon的重试跟超时机制,发现进行的全局超时配置一直不生效,配置如下:

ribbon:
  #单位ms,请求连接的超时时间,默认1000
  ConnectTimeout: 500
  #单位ms,读取数据的超时时间,默认1000
  ReadTimeout: 3000
  #对所有操作请求都进行重试
  #设置为true时,会对所有的请求进行重试,若为false只会对get请求进行重试
  #如果是put或post等写操作,
  #如果服务器接口没做幂等性,会产生不好的结果,所以OkToRetryOnAllOperations慎用。
  #默认情况下,GET方式请求无论是连接异常还是读取异常,都会进行重试
  #非GET方式请求,只有连接异常时,才会进行重试
  OkToRetryOnAllOperations: true
  #切换实例的重试次数,默认为1
  MaxAutoRetriesNextServer: 1
  #如果不配置ribbon的重试次数
  #对当前实例的重试次数,默认为0
  MaxAutoRetries: 2
  #为true的时候会关闭懒加载
  #Ribbon进行客户端负载均衡的Client并不是在服务启动的时候就初始化好的,
  #而是在调用的时候才会去创建相应的Client,所以第一次调用的耗时不仅仅包含发送HTTP请求的时间,还包含了创建RibbonClient的时间
  #这样一来如果创建时间速度较慢,同时设置的超时时间又比较短的话,第一次请求很容易超时
  eager-load:
    enabled: true
    #指定需要关闭懒加载的服务名
    clients: eureka-client

测了一天后,解决方案如下:

1.解决全局配置不生效的问题

@Bean
@LoadBalanced
public RestTemplate ribbonRestTemplate() {
    HttpComponentsClientHttpRequestFactory factory = new HttpComponentsClientHttpRequestFactory();
    factory.setReadTimeout(2000);
    factory.setConnectTimeout(2000);
    return new RestTemplate(factory);
}

因为Ribbon层走的一定是RestTemplate,所以我们可以直接配置这个RestTemplate的配置

1.解决重试不生效的问题:

pom中需要新增依赖:

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

启动类新增注解:@EnableRetry

关于重试为什么不生效我一直没找到原因,希望有懂的大佬能不吝赐教!!!!

我的版本:

Spring Boot版本:2.1.4.RELEASE

Spring Cloud版本:Greenwich.SR1

相关文章
|
2月前
|
Java 开发工具 Spring
Spring的Factories机制介绍
Spring的Factories机制介绍
39 1
|
3月前
|
安全 Java API
构建基于Spring Boot的REST API安全机制
构建基于Spring Boot的REST API安全机制
|
4月前
|
负载均衡 算法 Java
Spring Cloud Netflix 之 Ribbon
Spring Cloud Netflix Ribbon是客户端负载均衡器,用于在微服务架构中分发请求。它与RestTemplate结合,自动在服务发现(如Eureka)注册的服务之间进行调用。配置包括在pom.xml中添加依赖,设置application.yml以连接Eureka服务器,并在配置类中创建@LoadBalanced的RestTemplate。通过这种方式,当调用如`/user/userInfoList`的接口时,Ribbon会自动处理到多个可用服务实例的负载均衡。
|
4月前
|
JSON Java 程序员
马程序员2024最新SpringCloud微服务开发与实战 个人学习心得、踩坑、与bug记录Day1最快 最全(2)
马程序员2024最新SpringCloud微服务开发与实战 个人学习心得、踩坑、与bug记录Day1最快 最全(2)
42 3
|
4月前
|
程序员 测试技术 Docker
黑马程序员2024最新SpringCloud微服务开发与实战 个人学习心得、踩坑、与bug记录Day3 全网最全
黑马程序员2024最新SpringCloud微服务开发与实战 个人学习心得、踩坑、与bug记录Day3 全网最全(1)
312 1
|
3月前
|
Java Spring
解析Spring Boot中的事务管理机制
解析Spring Boot中的事务管理机制
|
3月前
|
缓存 安全 Java
Spring Boot中的自动配置机制详解
Spring Boot中的自动配置机制详解
|
4月前
|
设计模式 Java Spring
Spring Boot中的事件通知机制
Spring Boot中的事件通知机制
|
4月前
|
缓存 负载均衡 算法
技术笔记:springcloud深入学习(四)
技术笔记:springcloud深入学习(四)
|
4月前
|
缓存 Java Maven
深入解析Google Guava库与Spring Retry重试框架
深入解析Google Guava库与Spring Retry重试框架
下一篇
无影云桌面