问题描述
我正在尝试在 webservicetemplate 上设置超时,它仅在 21 秒以下时才有效,如果我尝试将超时设置为超过 21 秒,它将不起作用,每次达到 21 秒时都会超时。我尝试了很多配置,大多数都在做同样的事情。
@Bean
public webservicetemplate munisService() {
webservicetemplate template = new webservicetemplate();
template.setMarshaller(service1Marshaller());
template.setUnmarshaller(service1Marshaller());
template.setDefaultUri(ancomUrl);
HttpComponentsMessageSender httpComponentsMessageSender = new HttpComponentsMessageSender();
httpComponentsMessageSender.setReadTimeout(180000);
httpComponentsMessageSender.setConnectionTimeout(180000);
template.setMessageSender(httpComponentsMessageSender);
return template;
}
@Bean
ServiceImpl ServiceBean(Jaxb2Marshaller marshaller) {
ServiceImpl service= new ServiceImpl ();
service.setwebservicetemplate(munisService());
service.setDefaultUri(ancomUrl);
service.setMarshaller(marshaller);
service.setUnmarshaller(marshaller);
return service;
}
有谁知道为什么会这样? 如果有帮助,这是例外,我正在使用 httpclient 4.5.13
org.springframework.ws.client.WebServiceIOException: I/O error: Connection timed out: connect; nested exception is java.net.ConnectException: Connection timed out: connect
此外,请求是在 localhost 上完成的,我正在 localhost 上运行一个 Spring Boot 应用程序,它会执行一些请求。
解决方法
如果您使用带有 Spring Boot 的嵌入式服务器,请尝试将此配置属性放在 application.yaml
中
server.connection-timeout=120s
可能是服务器本身在 21 秒后强制连接超时
你能试试你的代码吗
httpComponentsMessageSender.setReadTimeout(0);
httpComponentsMessageSender.setConnectionTimeout(0);
根据文档 0
值表示永不超时。然后我们可能会从日志中检索更多关于导致超时的原因。