WebService / java.net.SocketTimeoutException: тайм-аут чтения - PullRequest
6 голосов
/ 11 марта 2011

У меня возникла проблема в WebService, более подробно:

Caused by: org.apache.cxf.interceptor.Fault: Could not send Message.
at org.apache.cxf.interceptor.MessageSenderInterceptor$MessageSenderEndingInterceptor.handleMessage(MessageSenderInterceptor.java:64)
at org.apache.cxf.phase.PhaseInterceptorChain.doIntercept(PhaseInterceptorChain.java:220)
at org.apache.cxf.endpoint.ClientImpl.invoke(ClientImpl.java:276)
at org.apache.cxf.endpoint.ClientImpl.invoke(ClientImpl.java:222)
at org.apache.cxf.frontend.ClientProxy.invokeSync(ClientProxy.java:73)
at org.apache.cxf.jaxws.JaxWsClientProxy.invoke(JaxWsClientProxy.java:171)
... 26 more
Caused by: java.net.SocketTimeoutException: Read timed out
at java.net.SocketInputStream.socketRead0(Native Method)
at java.net.SocketInputStream.read(SocketInputStream.java:129)
at java.io.BufferedInputStream.fill(BufferedInputStream.java:218)
at java.io.BufferedInputStream.read1(BufferedInputStream.java:258)
at java.io.BufferedInputStream.read(BufferedInputStream.java:317)
at sun.net.www.http.HttpClient.parseHTTPHeader(HttpClient.java:687)
at sun.net.www.http.HttpClient.parseHTTP(HttpClient.java:632)
at sun.net.www.protocol.http.HttpURLConnection.getInputStream(HttpURLConnection.java:1000)
at java.net.HttpURLConnection.getResponseCode(HttpURLConnection.java:373)
at org.apache.cxf.transport.http.HTTPConduit$WrappedOutputStream.handleResponse(HTTPConduit.java:1900)
at org.apache.cxf.transport.http.HTTPConduit$WrappedOutputStream.close(HTTPConduit.java:1828)
at org.apache.cxf.transport.AbstractConduit.close(AbstractConduit.java:66)
at org.apache.cxf.transport.http.HTTPConduit.close(HTTPConduit.java:590)
at org.apache.cxf.interceptor.MessageSenderInterceptor$MessageSenderEndingInterceptor.handleMessage(MessageSenderInterceptor.java:62)
... 31 more

Когда я пытаюсь отправить запрос целевой службе, это занимает 30-60 секунд, а затем выдается исключение, указанное выше. Я использую Tomcat 5, и я хотел бы спросить, есть ли способ увеличить значение тайм-аута? Кроме того, WSDL и WebService, к которым я хочу получить доступ, работают и доступны.

Я очень ценю любую помощь в этом,

С уважением, П.

Ответы [ 3 ]

3 голосов
/ 11 марта 2011

Вам нужно установить «ReceiveTimeout» для этого запроса.

Эта страница содержит сведения о добавлении этого свойства в контекст запроса:

http://cxf.apache.org/docs/developing-a-consumer.html

2 голосов
/ 22 апреля 2015

Я немного опоздал на эту вечеринку, но я попробовал другие решения, и они не сработали, но это сработало.

MyWebService service = new MyWebService();
MyWebServicePortType client = service.MyWebServicePort();

Client cl = ClientProxy.getClient(client);

HTTPConduit http = (HTTPConduit) cl.getConduit();

HTTPClientPolicy httpClientPolicy = new HTTPClientPolicy();
httpClientPolicy.setConnectionTimeout(0);
httpClientPolicy.setReceiveTimeout(0);

http.setClient(httpClientPolicy);

client.doSomething(...);
0 голосов
/ 06 февраля 2014

Прямо перед тем, как вы совершите вызов веб-службы (т.е. port.someAction(....)), вам нужно установить значение Время ожидания запроса на большее значение в requestContext:

    // Set request context property.
    java.util.Map<String, Object> requestContext =
      ((javax.xml.ws.BindingProvider) port).getRequestContext();

    requestContext.put("com.sun.xml.ws.request.timeout", new Long(600000));

Или, если вы используете JAX-WS:

    // Set request context property.
    java.util.Map<String, Object> requestContext =
      ((javax.xml.ws.BindingProvider) port).getRequestContext();

    requestContext.put("com.sun.xml.internal.ws.request.timeout", new Long(600000));

Вот пост, который действительно помог мне:

Как установить время ожидания для клиента веб-службы JAX-WS?

...