FeignClient 超时设置

在使用 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);

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值
>