使用RestTemplate的spring Web服务的超时配置



我想使用RestTemplate在客户端为spring Web服务配置一个超时。我尝试了以下配置:

<bean id="restTemplate" class="org.springframework.web.client.RestTemplate">
<constructor-arg>
    <bean class="org.springframework.http.client.CommonsClientHttpRequestFactory">
    <property name="readTimeout" value="10000" />
    </bean>
</constructor-arg>
    <property name="messageConverters">
    <list>
    <ref bean="stringHttpMessageConverter" />
    <ref bean="marshallingHttpMessageConverter" />
    </list>
    </property>
</bean>

但当我启动tomcat:时,我有一个NoClassDefFoundError

06 févr. 2012 10:43:43,113 [ERROR,ContextLoader] Context initialization failed
java.lang.NoClassDefFoundError: org/apache/commons/httpclient/HttpMethodBase

然而,我在pom.xml中包含了commons-httpclient:

    <dependency>
        <groupId>commons-httpclient</groupId>
        <artifactId>commons-httpclient</artifactId>
        <version>3.1</version>
    </dependency

你知道我该怎么做/修吗?

提前感谢!

Snicolas的回答几乎对我有效,只需要更改演员阵容类别:

RestTemplate restTemplate = new RestTemplate();    
((SimpleClientHttpRequestFactory)restTemplate.getRequestFactory()).setReadTimeout(1000*30);

您还可以设置连接超时:

((SimpleClientHttpRequestFactory)restTemplate.getRequestFactory()).setConnectTimeout(1000*30);

这对我有效

( (HttpComponentsClientHttpRequestFactory) getRestTemplate().getRequestFactory() ).setReadTimeout( 120 * 1000 );

我在安卓版本的春季安卓休息模板中使用了它。


默认值为60*1000

我遇到了同样的问题,首先尝试通过修改Spring配置来修复它但我的尝试都没有成功。

最后,我通过设置以下JVM系统属性部分修复了它:sun.net.client.defaultConnectTimeout

sun.net.client.defaultReadTimeout

(有关它们的更多详细信息,请访问该链接:http://docs.oracle.com/javase/1.4.2/docs/guide/net/properties.html)

首先,我为"连接超时"注入自定义值和存储在属性文件中的"读取超时",通过使用"自制"配置bean:

   <bean id="rmProperties"  class="com.mydomain.myapp.myConfigBean" scope="singleton">
    ...
    <property name="httpRequestConnectTimeout" value="${httpRequestConnectTimeout}" />
    <property name="httpRequestReadTimeout" value="${httpRequestReadTimeout}" />
    ...
    </bean>

然后,我使用system.setProperty(…)方法设置JVM系统属性,如下所示:

    System.setProperty(propName, value);

我只剩下一个问题:sun.net.client.defaultConnectTimeout中设置的值似乎没有被考虑在内。在进行了更多的测试后,我意识到当我试图通过代理服务器(在我的例子中是Squid)到达目标主机时,就会发生这种情况。

然而,使用这种设置方法有一个不便之处:超时设置将用于所有进一步的请求

问候

我也有同样的需求,即能够为Web服务消耗设置超时,我只是用另一个spring-conf来解决它。

首先使用下面的配置,我遇到了与@jsebFrank(java.lang.NoClassDefFoundError:org/apache/commons/httpclient/HttpMethodBase)相同的问题

    <bean id="restTemplate" class="org.springframework.web.client.RestTemplate">
    <constructor-arg>
        <bean
            class="org.springframework.http.client.CommonsClientHttpRequestFactory">
            <property name="connectTimeout" value="10000" />
            <property name="readTimeout" value="10000" />
        </bean>
    </constructor-arg>
    </bean>

但是,正如Spring支持在这里解释的那样(在第16.5节"超时处理"中),您可以使用SimpleClientHttpRequestFactory请求工厂(这是Spring restTemplate的默认工厂)。

使用它,我不再有问题:

    <bean id="restTemplate" class="org.springframework.web.client.RestTemplate">
    <constructor-arg>
        <bean
            class="org.springframework.http.client.SimpleClientHttpRequestFactory">
            <property name="connectTimeout" value="10000" />
            <property name="readTimeout" value="10000" />
        </bean>
    </constructor-arg>
    </bean>

相关内容

  • 没有找到相关文章

最新更新