WebServiceTemplate 超时仅在配置在 21 秒以下时有效

问题描述

我正在尝试在 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 值表示永不超时。然后我们可能会从日志中检索更多关于导致超时的原因。

spring documentation for httpComponentsMessageSender