Mule - HTTP Post - 超时超时

时间:2016-03-12 14:39:37

标签: http post timeout mule httprequest

这是我的基本mule flow

HTTP Listener> Logger> Http Request> Logger(结果讯息)

<http:request-config name="HTTP_Request_Configuration" host="localhost" port="8080" doc:name="HTTP Request Configuration" usePersistentConnections="false"/>
<http:listener-config name="HTTP_Listener_Configuration" host="0.0.0.0" port="8081" doc:name="HTTP Listener Configuration"/>
<flow name="servoy-restFlow">
    <http:listener config-ref="HTTP_Listener_Configuration"
        path="/" doc:name="HTTP" />
    <logger message="#[message.payloadAs(java.lang.String)]" level="INFO"
        doc:name="Logger" />
    <http:request config-ref="HTTP_Request_Configuration"
        path="service/rest/request" method="POST"
        doc:name="HTTP" />
    <logger message="#[message.payloadAs(java.lang.String)]" level="INFO"
        doc:name="Logger" />
</flow>

但它返回有关超时异常的错误:

********************************************************************************
Exception stack is:
1. Timeout exceeded (java.util.concurrent.TimeoutException)
  com.ning.http.client.providers.grizzly.GrizzlyAsyncHttpProvider:426 (null)
2. Error sending HTTP request. Message payload is of type: String (org.mule.api.MessagingException)
  org.mule.module.http.internal.request.DefaultHttpRequester:287 (http://www.mulesoft.org/docs/site/current3/apidocs/org/mule/api/MessagingException.html)
********************************************************************************
Root Exception stack trace:
java.util.concurrent.TimeoutException: Timeout exceeded
    at com.ning.http.client.providers.grizzly.GrizzlyAsyncHttpProvider.timeout(GrizzlyAsyncHttpProvider.java:426)
    at com.ning.http.client.providers.grizzly.GrizzlyAsyncHttpProvider$3.onTimeout(GrizzlyAsyncHttpProvider.java:274)
    at org.glassfish.grizzly.utils.IdleTimeoutFilter$DefaultWorker.doWork(IdleTimeoutFilter.java:398)
    at org.glassfish.grizzly.utils.IdleTimeoutFilter$DefaultWorker.doWork(IdleTimeoutFilter.java:377)
    at org.glassfish.grizzly.utils.DelayedExecutor$DelayedRunnable.run(DelayedExecutor.java:158)
    at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142)
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617)
    at java.lang.Thread.run(Thread.java:745)

********************************************************************************

我该怎么做才能避免超时?

5 个答案:

答案 0 :(得分:5)

http default的{​​{1}}超时在mule中的outbound request中指定为30秒。将http-request config的超时时间增加到30秒以上,可能是以40秒开始,看看你想要的号码是什么。

ms

答案 1 :(得分:2)

尝试增加超时:

<http:request-config responseTimeout="XYZ" />

答案 2 :(得分:1)

您可以为整个应用程序设置超时,在.xml的开头配置全局deafult超时属性,例如:

<configuration defaultTransactionTimeout="90000" defaultResponseTimeout="90000" doc:name="Configuration">
    <default-threading-profile poolExhaustedAction="RUN"/>
</configuration>

我希望这会有所帮助。

答案 3 :(得分:0)

采取另一种方法解决这个问题......

您尝试使用的服务是否存在问题,而且它没有响应。我总是发现默认超时足够(即使是调用外部服务)。

答案 4 :(得分:0)

如果您收到POST请求 - 可能是方法或微流,则会先执行操作,然后执行POST。如果您无法更改逻辑并删除它们,只需在Mule中增加请求配置中的超时。