java.net.SocketTimeoutException: Read timed out WebServiceTe



我在使用 WebserviceTemplate 调用 SOAP 服务时遇到以下异常。我正在使用代理连接到终结点 URL。

以下是我的 XML 配置:

    <bean id="webServiceTemplate" class="org.springframework.ws.client.core.WebServiceTemplate">
    <property name="marshaller" ref="jaxb2Marshaller"></property>
    <property name="unmarshaller" ref="jaxb2Marshaller"></property>
    <property name="defaultUri"><value>${ws.url}</value></property>
    <property name="interceptors">  
        <list>  
            <ref local="wsClientSecurityInterceptor"/>  
        </list>  
    </property>
    <property name="messageSender" ref="messageSender"></property>
    </bean>
    <bean id="messageSender" class="org.springframework.ws.transport.http.CommonsHttpMessageSender">
    <constructor-arg ref="httpClient"></constructor-arg>
    </bean>
    <!-- This is my custom class to set the proxy -->
    <bean id="proxyConfig" class="com.somepackage.client.ProxyConfiguration">
    <property name="proxyHostPlusPort"><value>${proxy.host}:${proxy.port}</value></property>
    </bean>
    <bean id="httpParams" class="org.apache.commons.httpclient.params.HttpClientParams">
    <property name="soTimeout" value="120000" /> 
    </bean>
    <bean id="httpClient" class="org.apache.commons.httpclient.HttpClient">
    <property name="hostConfiguration" ref="proxyConfig" />
    <property name="params" ref="httpParams" />
    </bean>
    <bean id="jaxb2Marshaller" class="org.springframework.oxm.jaxb.Jaxb2Marshaller">
    <property name="packagesToScan">
        <list><value>com.aaa.wsdl</value></list>
    </property>
    </bean>
    <bean id="wsClientSecurityInterceptor"  
    class="org.springframework.ws.soap.security.wss4j.Wss4jSecurityInterceptor">  
    <property name="securementActions" value="UsernameToken" />  
    <property name="securementUsername"><value>${ws.username}</value></property>  
    <property name="securementPassword"><value>${ws.password}</value></property>
    <property name="securementPasswordType" value="PasswordText" />
    </bean>

有时我在调用网络服务时遇到以下异常:

org.springframework.ws.client.WebServiceIOException: I/O error: Read timed out; nested exception is java.net.SocketTimeoutException: Read timed out
at org.springframework.ws.client.core.WebServiceTemplate.sendAndReceive(WebServiceTemplate.java:561)
at org.springframework.ws.client.core.WebServiceTemplate.marshalSendAndReceive(WebServiceTemplate.java:390)
at org.springframework.ws.client.core.WebServiceTemplate.marshalSendAndReceive(WebServiceTemplate.java:383)

即使我已经设置了 soTimeout,我也遇到了这个问题。我怀疑的是,当代理关闭超过 2 分钟时出现问题。

有人可以指导我如何摆脱这个问题吗?单独设置 soTimeout 就足够了,还是我们需要设置更多参数?

谢谢。

您不能忽略较低级别的(硬件/网络)错误,话虽如此,您可以通过在应用程序中添加一些智能来跟踪它们并做出相应的响应。

例如,通过进行几次额外的尝试等。为了拥有更强大的应用程序。

经过几次尝试后,您可以向用户发送一条消息,指出存在网络问题,即请求现在无法满足,并使用记录器对其进行跟踪。

如果这种情况确实很常见,则应在基础设施一级采取行动。

用:

-> try/catch, throw exception

相关内容

  • 没有找到相关文章

最新更新