无法配置Feign客户端超时

问题描述 投票:0回答:1

我正在使用带有禁用负载均衡器的Feign客户端

@FeignClient(name = "my-client", url = "${myHost}", configuration = ClientContext.class)

因此,所有功能区属性都将被忽略。我试图通过不同的方式设置自定义超时,但Feign忽略所有它们并在60秒后抛出TimeoutException。我尝试使用的方法:在ClientContext中:1)

@Value("${feign.connectTimeout:10000}")
private int connectTimeout;

@Value("${feign.readTimeOut:300000}")
private int readTimeout;

@Bean
public Request.Options options() {
    return new Request.Options(connectTimeout, readTimeout);
}

2)

@Bean
public Request.Options options() {
    return new Request.Options(10_000, 300_000);
}

在bootstrap.properties文件中:1)

feign.client.default.connect-timeout=10000
feign.client.default.read-timeout=300000

2)

feign.client.default.config.connect-timeout=10000
feign.client.default.config.read-timeout=300000

3)

feign.client.default.connectTimeout=10000
feign.client.default.readTimeout=300000

4)

feign.client.default.config.connectTimeout=10000
feign.client.default.config.readTimeout=300000

错误堆栈跟踪是:

Error Message: feign.RetryableException: Read timed out executing GET http://myrequest...
Stacktrace: 
feign.FeignException.errorExecuting(FeignException.java:67)
feign.SynchronousMethodHandler.executeAndDecode(SynchronousMethodHandler.java:10)
feign.SynchronousMethodHandler.invoke(SynchronousMethodHandler.java:76)
feign.ReflectiveFeign$FeignInvocationHandler.invoke(ReflectiveFeign.java:103)

您能否建议我正确配置或发现上面的代码块有什么问题?

java spring spring-cloud-netflix spring-cloud-feign
1个回答
0
投票

正确的解决方案是

@Value("${feign.connectTimeout:10000}")
private int connectTimeout;

@Value("${feign.readTimeOut:300000}")
private int readTimeout;

@Bean
public Request.Options options() {
    return new Request.Options(connectTimeout, readTimeout);
}

并添加到.properties文件这一个payer-service-client.feign.hystrix.enabled=false

© www.soinside.com 2019 - 2024. All rights reserved.