在使用 Spring Cloud OpenFeign 时,FeignClient
默认的超时时间可能不满足你的需求。你可以通过几种方式来自定义这些超时设置。以下是一些常见的方法:
1. 使用 application.properties
或 application.yml
在 application.properties
或 application.yml
文件中,你可以直接设置 Feign 的超时时间。Feign 底层使用 Ribbon 作为客户端负载均衡器,因此这些超时设置实际上是作用于 Ribbon 的。
application.properties 示例:
# 连接超时时间,单位毫秒
feign.client.config.default.connectTimeout=5000
# 读取超时时间,单位毫秒
feign.client.config.default.readTimeout=5000
如果你只想为特定的 FeignClient
设置超时时间,可以将 default
替换为对应的 FeignClient
的名称:
# 为名为 myFeignClient 的 FeignClient 设置超时
feign.client.config.myFeignClient.connectTimeout=5000
feign.client.config.myFeignClient.readTimeout=5000
application.yml 示例:
feign:
client:
config:
default:
connectTimeout: 5000
readTimeout: 5000
myFeignClient:
connectTimeout: 5000
readTimeout: 5000
2. 使用 Java 配置
首先,创建一个 Feign 配置类,在这个类中你可以定义自定义的 Request.Options
或其他 Feign 相关的配置 Bean:
@Configuration
public class MyFeignClientConfig {
@Bean
public Request.Options options() {
return new Request.Options(10000, 60000); // 自定义连接超时和读取超时
}
// 你可以在这里定义其他 Feign 相关的配置 Bean
}
然后,在 FeignClient
注解中通过 configuration
属性引用这个配置类:
@FeignClient(name = "myFeignClient", configuration = MyFeignClientConfig.class)
public interface MyFeignClient {
// 定义你的远程调用方法
@GetMapping("/some-endpoint")
String someMethod();
}
3. 方法上添加
@PostMapping(value = "/feignUrl")
Response<Boolean> feignMethod(@RequestBody Map<String, Object> params, @RequestHeader(required = false,name = "options") Request.Options options);
会给方法上增加一个入参,调用时候传入设置的超时时间
Request.Options options = new Request.Options(60*1000,60*1000);
Response<Boolean> res = feignService.feignMethod(params, options);