首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > JAVA > Java Web开发 >

憋了很久的有关问题-java.net.SocketTimeoutException: Read timed out

2012-01-16 
憋了很久的问题-java.net.SocketTimeoutException: Read timed out憋了很久的问题-java.net.SocketTimeout

憋了很久的问题-java.net.SocketTimeoutException: Read timed out
憋了很久的问题-java.net.SocketTimeoutException: Read timed out 


【问题描述】请求一个webservice偶尔会返回异常,如下: 
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.read(BufferedInputStream.java:235) 
  at weblogic.net.http.MessageHeader.isHTTP(MessageHeader.java:220) 
  at weblogic.net.http.MessageHeader.parseHeader(MessageHeader.java:143) 
  at weblogic.net.http.HttpClient.parseHTTP(HttpClient.java:420) 
  at weblogic.net.http.HttpURLConnection.getInputStream(HttpURLConnection.java:345) 
  at weblogic.net.http.SOAPHttpURLConnection.getInputStream(SOAPHttpURLConnection.java:31) 
  at com.lingtu.lbs.util.WebUtil.requestLBMP(WebUtil.java:735) 
  at com.lingtu.lbs.gis.webgis.doPost(webgis.java:99) 
  at javax.servlet.http.HttpServlet.service(HttpServlet.java:763) 
  at javax.servlet.http.HttpServlet.service(HttpServlet.java:856) 
  at weblogic.servlet.internal.StubSecurityHelper$ServletServiceAction.run(StubSecurityHelper.java:225) 
  at weblogic.servlet.internal.StubSecurityHelper.invokeServlet(StubSecurityHelper.java:127) 
  at weblogic.servlet.internal.ServletStubImpl.execute(ServletStubImpl.java:283) 
  at weblogic.servlet.internal.ServletStubImpl.execute(ServletStubImpl.java:175) 
  at weblogic.servlet.internal.WebAppServletContext$ServletInvocationAction.run(WebAppServletContext.java:3211) 
  at weblogic.security.acl.internal.AuthenticatedSubject.doAs(AuthenticatedSubject.java:321) 
  at weblogic.security.service.SecurityManager.runAs(SecurityManager.java:121) 
  at weblogic.servlet.internal.WebAppServletContext.securedExecute(WebAppServletContext.java:1983) 
  at weblogic.servlet.internal.WebAppServletContext.execute(WebAppServletContext.java:1890) 
  at weblogic.servlet.internal.ServletRequestImpl.run(ServletRequestImpl.java:1344) 
  at weblogic.work.ExecuteThread.execute(ExecuteThread.java:209) 
  at weblogic.work.ExecuteThread.run(ExecuteThread.java:181) 

这个异常并不是每次都抛出,而是当对方的webservice响应时间超过约2秒的时候才会抛出,我的程序并没有设置超时,而在家中的调试环境去访问这个webservice这种异常无法重现,已经排除了网络问题以及编码上的问题。所以我考虑是操作系统或weblogic设置不当(我方程序的weblogic容器,因为我们weblogic处理的http请求也很多)所引起,请大家帮我看看是什么原因?不胜感激!!! 

就是我在我们的weblogic中部署了一个war,这个war里面有一个类去请求另一个webservice,但是发现当对方返回响应的时候,有时我这边会抛出timeout异常,已经对网络进行抓包,发现我们产生异常的时候,对方的响应还没有发送完毕,我方主机就发送了断开连接的包。这个包我的程序肯定没有发,我怀疑是操作系统或者weblogic的原因。 

我用的是weblogic server9.2 有时请求和响应正常,有时请求响应不正常;请求不正常的时候抓包表现为:大约两秒左右,对方的响应还没有发送完毕,我方主机就发送了断开连接的包。 


[解决办法]
主要是客户端没有在限定的时间内将数据发送的服务器,可以通过setSoTimeout(int timeout)来设置socket超时。
[解决办法]
在web.xml中加入HungServerRecoverSecs这个参数,时间为秒.设置时长大点.
[解决办法]
to 深男大盗:
1.程序没有限制超时。

2.HungServerRecoverSecs是配置代理的,跟我这个请求响应有什么关系吗?

[解决办法]
在控制台把超时时间设置的大一点看看!
http://blog.csdn.net/ray_1981/archive/2007/12/10/1927540.aspx
[解决办法]
根本就没有设置超时时间,我说了2秒主机就发中断包,我曾经尝试过设置超时为30秒。

热点排行
Bad Request.