java.net.SocketTimeoutException: Read timed out 异常解决
问题描述: 使用RestTemplate调用对接系统接口时出现该异常
原因: httpClient在获取链接时候超时
解决: 将超时时间设置更长
SimpleClientHttpRequestFactory requestFactory = new SimpleClientHttpRequestFactory();
requestFactory.setConnectTimeout(66666);
requestFactory.setReadTimeout(66666);
restTemplate.setRequestFactory(requestFactory);
此处是由于项目中统一处理过这里的超时时长
而在源码中这里的链接和读取超时时长均为-1,即无超时情况.
提供一个工具类,可以进行统一处理该问题,也可在方法内具体方法具体处理
@Configuration
public class RestTemplateConfig {
@Bean
public RestTemplate restTemplate(@Qualifier("simpleClientHttpRequestFactory") ClientHttpRequestFactory factory){
RestTemplate restTemplate= new RestTemplate(factory);
restTemplate.getMessageConverters().set(1,new StringHttpMessageConverter(Charset.forName("UTF-8")));
return restTemplate;
}
@Bean
public ClientHttpRequestFactory simpleClientHttpRequestFactory(){
SimpleClientHttpRequestFactory factory = new SimpleClientHttpRequestFactory();
factory.setReadTimeout(120000);
factory.setConnectTimeout(120000);
return factory;
}
}