直奔主题,FeignClient面对服务级有三种超时时间配置:
feign配置(最常用)
feign:
sentinel:
enabled: true
client:
config:
default://全部服务配置
connectTimeout: 5000
readTimeout: 5000
loggerLevel: FULL
serversname://单独给某一服务配置 这里的serversname是服务名,使用的时候要用服务名替换掉这个
connectTimeout: 5000
readTimeout: 5000
ribbon配置
ribbon:
ReadTimeout:毫秒时间 同feign一样的
ConnectTimeout:毫秒时间 同feign一样的
feign配置是在ribbon配置的基础上做了扩展,可以支持服务级超时时间配置,所以,feign配置和ribbon配置的效果应该是一样的。
SpringCloud对这两种配置的优先级顺序如下:
Feign局部配置 > Feign全局配置 > Ribbon局部配置 > Ribbon全局配置
hystrix配置
hystrix:
command:
default://default默认为所有接口,可以配置指定接口
execution:
isolation:
thread:
timeoutInMilliseconds:毫秒时间
单独给某接口设置超时时间
在feign-core的jar包里有个Request类
import feign.Request;
在feign接口里加入这个参数就可以单独为接口单独设置超时时间了
@PostMapping("test/")
ResponseVO<?> test(Request.Options options, @RequestBody TestRequestEntity entity);
调用的时候new 一下Options对象
ResponseVO<?> resp = client.test(
new Request.Options(70, TimeUnit.SECONDS, 70, TimeUnit.SECONDS, true),
entity);
这样就可以为那些单独需要很长时间才能完成的接口(比如大文件上传等)设置超时时间了。
参考:https://www.cnblogs.com/east7/p/15858644.html
https://www.jianshu.com/p/d4d183f0be5b