我有这个Gradle依赖项的Spring Boot应用程序:
compile("org.springframework.cloud:spring-cloud-starter-eureka")
compile("org.springframework.cloud:spring-cloud-starter-feign")
compile("org.springframework.cloud:spring-cloud-starter-ribbon")
compile("org.springframework.cloud:spring-cloud-starter-hystrix")
compile("org.springframework.cloud:spring-cloud-starter-config")
我也有Feign客户端:
@FeignClient(name = "client")
public interface FeignService {
@RequestMapping(value = "/path", method = GET)
String response();
}
我的application.properties
:
client.ribbon.listOfServers = http://localhost:8081
ribbon.eureka.enabled=false
当查询时间超过1秒时,我得到例外:
com.netflix.hystrix.exception.HystrixRuntimeException: response timed-out and no fallback available.
所以我的问题是:如何设置自定义Feign客户端连接超时?例如2秒。
答案 0 :(得分:16)
我在问题上使用answer解决了我的问题: Hystrix command fails with “timed-out and no fallback available” 。
我将hystrix.command.default.execution.isolation.thread.timeoutInMilliseconds=4000
添加到application.properties
以设置自定义超时。
答案 1 :(得分:1)
可以使用application.yaml文件上的配置属性来配置超时:
feign:
client:
config:
default:
connectTimeout: 5000
readTimeout: 5000
请注意,这将更改您的默认伪装配置,如果您仅想为客户端更新超时,则将default
用@FeignClient
中配置的名称替换为{{1} },另一件事是您必须同时指定client
和connectTimeout
才能生效。
有关更多详细信息,请参见:documentation