Spring Cloud各组件超时总结
Ribbon的超时
- 全局设置:
 
ribbon:
    ReadTimeout: 60000
    ConnectTimeout: 60000
- 1
 - 2
 - 3
 
- 局部设置:
 
service-id:
    ribbon:
    ReadTimeout:1000
    ConnectTimeout:1000
- 1
 - 2
 - 3
 - 4
 
其中, service-id 是Ribbon所使用的虚拟主机名,一般和Eureka Server上注册的服务名称一致,即:与 spring.application.name 一致。
Feign的超时
从Spring Cloud Edgware开始,Feign支持使用属性配置超时:
feign:
    client:config:
        feignName:
            connectTimeout:5000
            readTimeout:5000
- 1
 - 2
 - 3
 - 4
 - 5
 
对于老版本,可以写个 feign.Request.Options ,参考: org.springframework.cloud.netflix.feign.ribbon.FeignRibbonClientAutoConfiguration#feignRequestOptions 的写法即可。
RestTemplate的超时
一些时侯,我们可能使用了RestTemplate,例如
@Bean
@LoadBalanced
public RestTemplate restTemplate ()
{
  return new RestTemplate ();
}
- 1
 - 2
 - 3
 - 4
 - 5
 - 6
 
此时,超时可使用如下方式设置:
@Bean
@LoadBalanced
public RestTemplate restTemplate ()
{
SimpleClientHttpRequestFactory simpleClientHttpRequestFactory  = new SimpleClientHttpRequestFactory ();
simpleClientHttpRequestFactory.setConnectTimeout(1000);
simpleClientHttpRequestFactory.setReadTimeout(1000);
  return new RestTemplate(simpleClientHttpRequestFactory);
}
- 1
 - 2
 - 3
 - 4
 - 5
 - 6
 - 7
 - 8
 - 9
 
Zuul的超时
Zuul的超时比较复杂,因为Zuul整合了Ribbon、Hystrix。下面分两种情况讨论:
- 如果Zuul的路由使用了Ribbon 
那么:Zuul的超时则与Ribbon、Hystrix相关,此时Zuul的超时可以配置类似如下: 
hystrix:
    command:
        default:
            execution:
                isolation:
                    thread:
                        timeoutInMilliseconds:1000
                        ribbon:
                            ReadTimeout:1000
                            ConnectTimeout:1000
- 1
 - 2
 - 3
 - 4
 - 5
 - 6
 - 7
 - 8
 - 9
 - 10
 
代码解析:此种情况下,Zuul转发所使用的过滤器是 org.springframework.cloud.netflix.zuul.filters.route.RibbonRoutingFilter ,在这个过滤器中,整合了Hystrix以及Ribbon。
- 如果Zuul的路由未使用Ribbon 
例如:Zuul的路由配置如下: 
zuul:
    routes:
    user-route:      # 该配置方式中,user-route只是给路由一个名称,可以任意起名。
     url:http://localhost:8000/  # 指定的url
     path: /user/**      # url对应的路径。
- 1
 - 2
 - 3
 - 4
 - 5
 
那么,此时Zuul的超时只与如下两个配置有关:
zuul:
host:
    socket-timeout-millis:10000
    connect-timeout-millis:2000
- 1
 - 2
 - 3
 - 4
 - 5
 
代码解析:直接配置URL路由的方式,用不上Ribbon,也用不上Hystrix,Zuul转发所使用的过滤器是 org.springframework.cloud.netflix.zuul.filters.route.SimpleHostRoutingFilter ,在这个过滤器中,Zuul使用Apache HttpClient进行转发。 
在现实场景中,有时候可能两种路由方式配合使用,因此,建议大家配置以上所有属性。
Hystrix的超时
hystrix:
command:
    default:
        execution:
             timeout:
                 enabled:true
                isolation:
                    thread:
                        timeoutInMilliseconds:1000
- 1
 - 2
 - 3
 - 4
 - 5
 - 6
 - 7
 - 8
 - 9
 - 10
 
如上,Hystrix的默认超时时间是1秒。默认开启超时机制。如需关闭Hystrix的超时,可将xxx.enabled设置为false。
Tips
如有组件跟Hystrix配合使用,一般来讲,建议Hystrix的超时 > 其他组件的超时,否则将可能导致重试特性失效。
注:转载自周立SpringCloud
Spring Cloud各组件超时总结的更多相关文章
- Spring Cloud 各组件调优参数
		
Spring Cloud整合了各种组件,每个组件往往还有各种参数.本文来详细探讨Spring Cloud各组件的调优参数. Tomcat配置参数 1 server: 2 tomcat: 3 max-c ...
 - Spring Cloud各个组件的配套使用
		
我们从整体上来看一下Spring Cloud各个组件如何来配套使用: 从上图可以看出Spring Cloud各个组件相互配合,合作支持了一套完整的微服务架构. 其中Eureka负责服务的注册与发现, ...
 - Spring Cloud 各个组件介绍
		
从上图可以看出 Spring Cloud 各个组件相互配合,合作支持了一套完整的微服务架构: Eureka 负责服务的注册与发现,很好地将各服务连接起来. Hystrix 负责监控服务之间的调用情况, ...
 - Spring Cloud常用组件及各组件版本对应关系图
		
Spring Cloud常用组件: 架构图: 版本对应关系:
 - Spring Cloud feign 服务超时处理
		
Spring Cloud中,Feign和Ribbon在整合了Hystrix后,可能会出现首次调用失败的问题 造成该问题的原因 Hystrix默认的超时时间是1秒,如果超过这个时间尚未响应,将会进入fa ...
 - Spring Cloud Feign组件
		
采用Spring Cloud微服务框架后,经常会涉及到服务间调用,服务间调用采用了Feign组件. 由于之前有使用dubbo经验.dubbo的负载均衡策略(轮训.最小连接数.随机轮训.加权轮训),du ...
 - Spring Cloud各组件
		
讲的不错:http://www.ityouknow.com/springcloud/2017/05/16/springcloud-hystrix.html Spring Cloud技术应用从场景上可以 ...
 - Spring Cloud Config Client 超时与重试
		
简介 有时客户端需要在 config server 无响应时进行重试,以给 config server 时间进行恢复.利用 spring 提供的重试组件,我们可以方便的配置重试机制,包括重试间隔,重试 ...
 - Spring Cloud 各个组件角色简介
		
概述 SpringCloud 是一个全家桶式的技术栈,包含了很多组件:包含 Eureka.Ribbon.Feign.Zuul .Hystrix等.每个组件完成对应的功能 组件介绍 - 服务发现 Eur ...
 
随机推荐
- python pymssql 连接数据库
			
1)写在前面 远程连接数据库的时候,端口前面都是用的逗号, 因为惯性思维, 就傻傻的把 ip+,+端口 赋值给server了,然后一直报错, pymssql.InterfaceError: Co ...
 - locust 的使用
			
Contents Locust这一款开源性能测试工具.然而,当前在网络上针对Locust的教程极少,不管是中文还是英文,基本都是介绍安装方法和简单的测试案例演示,但对于较复杂测试场景的案例演示却基本没 ...
 - Hive常用语句
			
文章目录 1 显示分区 2 添加分区 3 删除分区 4 修改分区 5 添加列 6 修改列 7 修改表属性 8 表的重命名 显示分区 show partitions iteblog; 添加分区 ALTE ...
 - 利用PHP将图片转换成base64编码的实现方法
			
先来说一下为什么我们要对图片base64编码 base64是当前网络上最为常见的传输8Bit字节代码的编码方式其中之一.base64主要不是加密,它主要的用途是把某些二进制数转成普通字符用于网络传输. ...
 - JustOj 1936: 小明A+B
			
题目描述 小明今年3岁了, 现在他已经能够认识100以内的非负整数, 并且能够进行100以内的非负整数的加法计算. 对于大于等于100的整数, 小明仅保留该数的最后两位进行计算, 如果计算结果大于等于 ...
 - amoeba读写分离
			
第一单元 高性能mysql读写分离的实现 5.1 mysql读写分离 5.1.1 mysql读写分离概述 5.1.2 mysql读写分离原理 5.2 mysql读写分离配置 ...
 - Oracle12.2中新增的分区功能
			
Oracle 12.2已经发布一段时间,公网上也可以下载试用.针对12.2,partitioning(分区)也有了不少增强. 自动列表分区 多字段列表分区 只读分区 分区维护时允许过滤 在线转换非分区 ...
 - myBatis框架之入门(一)
			
什么是框架 框架就是一个架子,表演节目,舞台已经搭建好,表演什么节目,看自己的需求了. 框架是一个半成品,对于Java语言来说,框架就是封装了别人的代码.在框架的基础上我们在进一步开发,拿来主义. 框 ...
 - linux下SVN忽略指定文件/文件夹
			
http://www.cnblogs.com/fjping0606/p/4743009.html 1.配置SVN默认编辑器vi ~/.bash_profile最后一行加上:export SVN_EDI ...
 - Java线程安全容器
			
一.Java同步容器 同步容器是用来解决并发情况下的容器线程安全问题的.给多线程环境准备一个线程安全的容器对象. 线程安全的容器对象: Vector, Hashtable.线程安全容器对象,都是使用s ...