出现问题的前提
- SpringCloud间FeignClient调用出现ReadTimeOut的情况
- FeignClient服务间调用的默认超时时间为2秒
- 网上查找的解决方案
- 关闭Hystrix(馊主意)
- 延长超时间(Spring众多超时时间配置繁多)
解决方案
- 为FeignClient添加自定义的超时配置,结合Nacos可控
- 话不多说,贴出源码
/**
* FeignClient配置类
*
* @author gralves
* @date 2020/8/10
*/
@Component
public class FeignClientConfig {
// 连接超时
@Value("${service.feign.connectTimeout:60000}")
private int connectTimeout;
// 数据读取超时
@Value("${service.feign.readTimeOut:60000}")
private int readTimeout;
// 构造自定义配置类
@Bean
public Request.Options options() {
return new Request.Options(connectTimeout, readTimeout);
}
}
// configuration字段使用自定义配置
@FeignClient(value = "xxx", configuration = FeignClientConfig.class)
public interface XxxFeignClient {...
- 启动服务A/B,进行服务调用,断点59秒(不超时),断点60秒(ReadTimeOut).可以发现配置是生效的
建议
- 不同的服务可以配置不同的超时时间
- FeignClient可以抽成公共工具包进行使用
缺点