【发布时间】:2018-03-13 13:53:26
【问题描述】:
我正在使用禁用负载均衡器的 Feign 客户端
@FeignClient(name = "my-client", url = "${myHost}", configuration = ClientContext.class)
因此,所有功能区属性都将被忽略。 我正在尝试通过不同的方式设置自定义超时,但 Feign 忽略了所有这些并在 60 秒后抛出 TimeoutException。 我尝试使用的方法: 在客户端上下文中: 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)
你能建议我正确的配置还是发现上面的代码块有什么问题?
【问题讨论】:
-
你可能使用 hystrix 和 feign,它的超时时间默认是 1s。
-
我稍后添加了堆栈跟踪。没有提到任何hystrix。会不会是因为hystrix?
标签: java spring spring-cloud-netflix spring-cloud-feign