FeignClient面对服务级有三种超时时间配置
feign配置(最常用)
feign:
sentinel:
enabled: true
client:
config:
default://全部服务配置
connectTimeout: 5000
readTimeout: 5000
loggerLevel: FULL
serversname://单独给某一服务配置 这里的serversname是服务名,使用的时候要用服务名替换掉这个
connectTimeout: 5000
readTimeout: 5000
ribbon[ˈrɪbən]配置
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.bmabk.com/index.php/post/132274.html