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对象文章来源:https://www.toymoban.com/news/detail-530595.html
ResponseVO<?> resp = client.test(
new Request.Options(70, TimeUnit.SECONDS, 70, TimeUnit.SECONDS, true),
entity);
这样就可以为那些单独需要很长时间才能完成的接口(比如大文件上传等)设置超时时间了。文章来源地址https://www.toymoban.com/news/detail-530595.html
到了这里,关于【java】Spring Cloud --Feign Client超时时间配置以及单独给某接口设置超时时间方法的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!