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

zhaoqiubo 2007-12-13 01:43:09
憋了很久的问题-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 有时请求和响应正常,有时请求响应不正常;请求不正常的时候抓包表现为:大约两秒左右,对方的响应还没有发送完毕,我方主机就发送了断开连接的包。
...全文
122592 11 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
11 条回复
切换为时间正序
请发表友善的回复…
发表回复
emilyhonglin 2011-12-01
  • 打赏
  • 举报
回复
[Quote=引用 9 楼 quqi99 的回复:]
这是JDK的一个BUG,见SUN公司的BUG列表:http://bugs.sun.com/bugdatabase/view_bug.do?bug_id=4352956
[/Quote]

那有解决方法吗?
zygcs 2010-10-14
  • 打赏
  • 举报
回复
我也碰到了类似的情况。

检查了一下代码,
客户端发送时, out.print("XXXXX");

服务端接收时,in.readLine();

导到两边接收不一致。

后来客户端改为 out.println("XXXXX"); 服务端改为 in.readLine();

测试正常。


quqi99 2009-02-10
  • 打赏
  • 举报
回复
这是JDK的一个BUG,见SUN公司的BUG列表:http://bugs.sun.com/bugdatabase/view_bug.do?bug_id=4352956
MavenTalk 2008-12-17
  • 打赏
  • 举报
回复
同样的问题,咋没有兄弟搞出个解决方案
ypopo1234 2008-12-15
  • 打赏
  • 举报
回复
我也遇到了,烦
16:53:39,806 ERROR ZrarExceptionResolver:219 - Web端应用程序出现异常:
java.net.SocketTimeoutException: Read timed out
at java.net.SocketInputStream.socketRead0(Native Method)
at java.net.SocketInputStream.read(SocketInputStream.java:134)
at weblogic.servlet.internal.PostInputStream.read(PostInputStream.java:170)
at weblogic.servlet.internal.ServletInputStreamImpl.read(ServletInputStreamImpl.java:180)
at weblogic.servlet.internal.ServletRequestImpl.mergePostParams(ServletRequestImpl.java:1339)
at weblogic.servlet.internal.ServletRequestImpl.parseQueryParams(ServletRequestImpl.java:1206)
at weblogic.servlet.internal.ServletRequestImpl.getParameter(ServletRequestImpl.java:1409)
at weblogic.servlet.internal.ServletRequestImpl.getParameter(ServletRequestImpl.java:1395)
at com.cssnet.platform.baseframe.web.springextend.SwordDispatcherServlet.checkRequestType(SwordDispatcherServlet.java:285)
at com.cssnet.platform.baseframe.web.springextend.SwordDispatcherServlet.doDispatch2(SwordDispatcherServlet.java:108)
at com.cssnet.platform.baseframe.web.springextend.SwordDispatcherServlet.doDispatch(SwordDispatcherServlet.java:79)
at org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:623)
at org.springframework.web.servlet.FrameworkServlet.serviceWrapper(FrameworkServlet.java:384)
at org.springframework.web.servlet.FrameworkServlet.doPost(FrameworkServlet.java:353)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:760)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:853)
at weblogic.servlet.internal.ServletStubImpl$ServletInvocationAction.run(ServletStubImpl.java:1072)
at weblogic.servlet.internal.ServletStubImpl.invokeServlet(ServletStubImpl.java:465)
at weblogic.servlet.internal.TailFilter.doFilter(TailFilter.java:28)
at weblogic.servlet.internal.FilterChainImpl.doFilter(FilterChainImpl.java:27)
at com.cssnet.platform.baseframe.web.comm.CharacterEncodingFilter.doFilter(CharacterEncodingFilter.java:52)
at weblogic.servlet.internal.FilterChainImpl.doFilter(FilterChainImpl.java:27)
at com.cssnet.platform.biz.login.web.filter.TimeOutAndFunctionAuthCheckFilter.doFilter(TimeOutAndFunctionAuthCheckFilter.java:111)
at weblogic.servlet.internal.FilterChainImpl.doFilter(FilterChainImpl.java:27)
at weblogic.servlet.internal.WebAppServletContext$ServletInvocationAction.run(WebAppServletContext.java:6987)
at weblogic.security.acl.internal.AuthenticatedSubject.doAs(AuthenticatedSubject.java:321)
at weblogic.security.service.SecurityManager.runAs(SecurityManager.java:121)
at weblogic.servlet.internal.WebAppServletContext.invokeServlet(WebAppServletContext.java:3892)
at weblogic.servlet.internal.ServletRequestImpl.execute(ServletRequestImpl.java:2766)
at weblogic.kernel.ExecuteThread.execute(ExecuteThread.java:224)
at weblogic.kernel.ExecuteThread.run(ExecuteThread.java:183)
--------------- nested within: ------------------
weblogic.utils.NestedRuntimeException: Cannot parse POST parameters of request: '/ecjj/fw/XyHtHyfwCtrl-nextToinitHtData.pfv' - with nested exception:
[java.net.SocketTimeoutException: Read timed out]
at weblogic.servlet.internal.ServletRequestImpl.mergePostParams(ServletRequestImpl.java:1364)
at weblogic.servlet.internal.ServletRequestImpl.parseQueryParams(ServletRequestImpl.java:1206)
at weblogic.servlet.internal.ServletRequestImpl.getParameter(ServletRequestImpl.java:1409)
at weblogic.servlet.internal.ServletRequestImpl.getParameter(ServletRequestImpl.java:1395)
at com.cssnet.platform.baseframe.web.springextend.SwordDispatcherServlet.checkRequestType(SwordDispatcherServlet.java:285)
at com.cssnet.platform.baseframe.web.springextend.SwordDispatcherServlet.doDispatch2(SwordDispatcherServlet.java:108)
at com.cssnet.platform.baseframe.web.springextend.SwordDispatcherServlet.doDispatch(SwordDispatcherServlet.java:79)
at org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:623)
at org.springframework.web.servlet.FrameworkServlet.serviceWrapper(FrameworkServlet.java:384)
at org.springframework.web.servlet.FrameworkServlet.doPost(FrameworkServlet.java:353)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:760)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:853)
at weblogic.servlet.internal.ServletStubImpl$ServletInvocationAction.run(ServletStubImpl.java:1072)
at weblogic.servlet.internal.ServletStubImpl.invokeServlet(ServletStubImpl.java:465)
at weblogic.servlet.internal.TailFilter.doFilter(TailFilter.java:28)
at weblogic.servlet.internal.FilterChainImpl.doFilter(FilterChainImpl.java:27)
at com.cssnet.platform.baseframe.web.comm.CharacterEncodingFilter.doFilter(CharacterEncodingFilter.java:52)
at weblogic.servlet.internal.FilterChainImpl.doFilter(FilterChainImpl.java:27)
at com.cssnet.platform.biz.login.web.filter.TimeOutAndFunctionAuthCheckFilter.doFilter(TimeOutAndFunctionAuthCheckFilter.java:111)
at weblogic.servlet.internal.FilterChainImpl.doFilter(FilterChainImpl.java:27)
at weblogic.servlet.internal.WebAppServletContext$ServletInvocationAction.run(WebAppServletContext.java:6987)
at weblogic.security.acl.internal.AuthenticatedSubject.doAs(AuthenticatedSubject.java:321)
at weblogic.security.service.SecurityManager.runAs(SecurityManager.java:121)
at weblogic.servlet.internal.WebAppServletContext.invokeServlet(WebAppServletContext.java:3892)
at weblogic.servlet.internal.ServletRequestImpl.execute(ServletRequestImpl.java:2766)
at weblogic.kernel.ExecuteThread.execute(ExecuteThread.java:224)
at weblogic.kernel.ExecuteThread.run(ExecuteThread.java:183)
rick1212 2008-07-04
  • 打赏
  • 举报
回复
我和你遇到的问题一模一样,不知道该如何解决....
zhaoqiubo 2007-12-21
  • 打赏
  • 举报
回复
根本就没有设置超时时间,我说了2秒主机就发中断包,我曾经尝试过设置超时为30秒。
ray_1981 2007-12-13
  • 打赏
  • 举报
回复
在控制台把超时时间设置的大一点看看!
http://blog.csdn.net/ray_1981/archive/2007/12/10/1927540.aspx
zhaoqiubo 2007-12-13
  • 打赏
  • 举报
回复
to 深男大盗:
1.程序没有限制超时。

2.HungServerRecoverSecs是配置代理的,跟我这个请求响应有什么关系吗?
天外流星 2007-12-13
  • 打赏
  • 举报
回复
在web.xml中加入HungServerRecoverSecs这个参数,时间为秒.设置时长大点.
天外流星 2007-12-13
  • 打赏
  • 举报
回复
主要是客户端没有在限定的时间内将数据发送的服务器,可以通过setSoTimeout(int timeout)来设置socket超时。

81,122

社区成员

发帖
与我相关
我的任务
社区描述
Java Web 开发
社区管理员
  • Web 开发社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧