我们的Web应用程序中,用户可以提交一个URL。我们将在服务器端获取并解析数据。对于每个请求,我们使用一个带有以下(相关)设置的HttpClient:
connectionManager.getParams().setConnectionTimeout(10000);
connectionManager.getParams().setSoTimeout(10000);
当我调用HttpMethod.getResponseBody时,状态码已经被检查为可接受。此时线程会挂起,并显示以下堆栈跟踪:
java.net.SocketInputStream.socketRead0 ( native code )
java.net.SocketInputStream.read ( SocketInputStream.java:150 )
java.net.SocketInputStream.read ( SocketInputStream.java:121 )
java.io.BufferedInputStream.read1 ( BufferedInputStream.java:273 )
java.io.BufferedInputStream.read ( BufferedInputStream.java:334 )
java.io.FilterInputStream.read ( FilterInputStream.java:133 )
org.apache.commons.httpclient.AutoCloseInputStream.read ( AutoCloseInputStream.java:108 )
java.io.FilterInputStream.read ( FilterInputStream.java:107 )
org.apache.commons.httpclient.AutoCloseInputStream.read ( AutoCloseInputStream.java:127 )
org.apache.commons.httpclient.HttpMethodBase.getResponseBody ( HttpMethodBase.java:690 )
我无法确定发生这种情况的确切URL(这是在现场环境中发生的事件),并且我无法重现它。我想这可能只是我们连接到的服务器行为异常的问题,但也许我漏掉了什么。在任何情况下,有没有办法防止阻塞方法调用永远等待?SoTimeout也是套接字读取超时?还有其他设置我错过了吗?