feign服务间调用超时时间

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了feign服务间调用超时时间相关的知识,希望对你有一定的参考价值。

参考技术A 因为接口返回数据超时,直接执行了fallback,
配置项 hystrix.command.default(默认).execution.isolation.thread.timeoutInMilliseconds

hystrix.command.HystrixCommandKey(指定方法名 ).execution.isolation.thread.timeoutInMilliseconds

表示在调用方配置,被调用方的方法执行时间都是这个值,超过这个时间就会按超时处理执行fallback. defualt 优先级低于HystrixCommandKey

hystrix.command.default.execution.timeout.enabled=.
表示是否开启超时设置
为true ,则有两个执行方法的超时配置,一个是ribbon的readTimeout ,一个是hystrix的timeoutInMilliseconds 谁小谁生效。
为false,则只有ribbon的readTimeOut。

ribbon.ConnectTimeout 为服务的连接超时间,除非服务找不到,或者网络原因,这个时间才会生效。
由于ribbon的重试机制,通常熔断的超时时间需要配置的比ReadTimeout长,ReadTimeout比ConnectTimeout长,否则还未重试,就熔断了。
为了确保重试机制的正常运作,理论上(以实际情况为准)建议hystrix的超时时间为:(1 + MaxAutoRetries + MaxAutoRetriesNextServer) * ReadTimeout。

ribbon.eager-load.enabled : 开启Ribbon的饥饿加载模式 , 如果Ribbon进行客户端负载均衡的Client并不是在服务启动的时候就初始化好的,而是在调用的时候才会去创建相应的Client,所以第一次调用的耗时不仅仅包含发送HTTP请求的时间,还包含了创建RibbonClient的时间,这样一来如果创建时间速度较慢,同时设置的超时时间又比较短的话,很容易就会出现报错的情况。

ribbon.eager-load.clients: 指定需要饥饿加载的服务名

feign调用超时

Feign调用超时

feign调用超时 默认feign调用超时是1秒,断点调试是否调用成功肯定超时

feign.hystrix.enabled=true
#feign调用默认是1000毫秒=1秒    add by six-vision
hystrix.command.default.execution.isolation.thread.timeoutInMilliseconds=30000
hystrix.command.default.circuitBreaker.sleepWindowInMilliseconds=30000
hystrix.command.default.circuitBreaker.forceClosed=true
#hystrix.command.default.execution.timeout.enabled=false
#请求处理的超时时间  add by six-vision
ribbon.ReadTimeout=30000
ribbon.SocketTimeout=30000
#请求连接的超时时间 add by six-vision
ribbon.ConnectTimeout: 30000

以上是关于feign服务间调用超时时间的主要内容,如果未能解决你的问题,请参考以下文章

微服务调用时的超时异常,使用feign的时候负载均衡策略的调整

记:k8s内部服务调用连接超时

Spring Cloud 源码解读之 如何配置好OpenFeign的各种超时时间!

Feign Client超时时间配置以及单独给某接口设置超时时间方法记录

feign调用超时

Feign调用时读取超时(Read timed out executing GET)解决方法