[jboss-user] [Beginners Corner] - Having occasional SocketExceptions when talking to JBoss 4.2
eightmd
do-not-reply at jboss.com
Fri Dec 14 16:34:21 EST 2007
I tried to post this earlier but didn't see it show up. I apologize if it gets posted twice.
I'm not exactly new to JBoss but I've never dug down very deep into it. I've looked around and haven't been able to answer my question so any help would beappreciated.
I'm running some tests with my application in JBoss using httpClient 3.0.1 to send the URLs to Apache 2.2.6, which routes them to JBoss 4.2.2GA. Java release is 1.5.0.10. My client machine is running Linux 2.6.15.4 Fedora Core 3. The server running JBoss is running Linux 2.6.18-1.2869.fc6. I am running my testin Eclipse 3.1.0.
My test client is getting about 10% errors. Most of them are java.net.ConnectException: Connection refused but some are java.net.SocketException: Connection reset. When I look in the JBoss log I see it's getting some ClientAbortException: java.net.SocketException: Broken pipe.
Obviously JBoss is listening on the port and performs most of the requests. I am not hitting the server all that hard. My test client will see this happen when it sends a request every 5 seconds. The requests involve uploading a file. Maximum threads I'm allowing for JBoss is 200 and its only using around 18. I think Apache has around 200 but I'm not sure.
It looks like the server thinks the client is closing the connection at times. Looks like the client is getting the connection reset by the server (connection reset), and the server is not listening sometimes (connection refused).
If anyone has any ideas that I should try please let me know. Thanks in advance.
Server and client stack traces follow.
This is the stack trace from the JBoss server log:
23:37:01,973 ERROR [STDERR] ClientAbortException: java.net.SocketException: Broken pipe
23:37:01,974 ERROR [STDERR] at org.apache.catalina.connector.OutputBuffer.realWriteBytes(OutputBuffer.java:358)
23:37:01,974 ERROR [STDERR] at org.apache.tomcat.util.buf.ByteChunk.flushBuffer(ByteChunk.java:434)
23:37:01,974 ERROR [STDERR] at org.apache.tomcat.util.buf.ByteChunk.append(ByteChunk.java:349)
23:37:01,974 ERROR [STDERR] at org.apache.catalina.connector.OutputBuffer.writeBytes(OutputBuffer.java:381)
23:37:01,974 ERROR [STDERR] at org.apache.catalina.connector.OutputBuffer.write(OutputBuffer.java:370)
23:37:01,974 ERROR [STDERR] at org.apache.catalina.connector.CoyoteOutputStream.write(CoyoteOutputStream.java:89)
23:37:01,974 ERROR [STDERR] at org.apache.catalina.connector.CoyoteOutputStream.write(CoyoteOutputStream.java:83)
23:37:01,974 ERROR [STDERR] at com.convera.ews.commons.EWSUtils.sendDocument(EWSUtils.java:194)
23:37:01,974 ERROR [STDERR] at com.convera.ews.core.servlet.ExcaliburWSAdminServlet.doRequest(ExcaliburWSAdminServlet.java:323)
23:37:01,974 ERROR [STDERR] at com.convera.ews.core.servlet.ExcaliburWSAdminServlet.doGet(ExcaliburWSAdminServlet.java:684)
23:37:01,974 ERROR [STDERR] at javax.servlet.http.HttpServlet.service(HttpServlet.java:690)
23:37:01,974 ERROR [STDERR] at javax.servlet.http.HttpServlet.service(HttpServlet.java:803)
23:37:01,974 ERROR [STDERR] at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:290)
23:37:01,974 ERROR [STDERR] at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
23:37:01,974 ERROR [STDERR] at org.jboss.web.tomcat.filters.ReplyHeaderFilter.doFilter(ReplyHeaderFilter.java:96)
23:37:01,974 ERROR [STDERR] at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:235)
23:37:01,974 ERROR [STDERR] at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
23:37:01,975 ERROR [STDERR] at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:230)
23:37:01,975 ERROR [STDERR] at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:175)
23:37:01,975 ERROR [STDERR] at org.jboss.web.tomcat.security.SecurityAssociationValve.invoke(SecurityAssociationValve.java:179)
23:37:01,975 ERROR [STDERR] at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:524)
23:37:01,975 ERROR [STDERR] at org.jboss.web.tomcat.security.JaccContextValve.invoke(JaccContextValve.java:84)
23:37:01,975 ERROR [STDERR] at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:127)
23:37:01,975 ERROR [STDERR] at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:102)
23:37:01,975 ERROR [STDERR] at com.convera.ews.logging.valves.EWSAccessLogValve.invoke(EWSAccessLogValve.java:492)
23:37:01,975 ERROR [STDERR] at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:109)
23:37:01,975 ERROR [STDERR] at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:262)
23:37:01,975 ERROR [STDERR] at org.apache.coyote.ajp.AjpProcessor.process(AjpProcessor.java:437)
23:37:01,975 ERROR [STDERR] at org.apache.coyote.ajp.AjpProtocol$AjpConnectionHandler.process(AjpProtocol.java:366)
23:37:01,975 ERROR [STDERR] at org.apache.tomcat.util.net.JIoEndpoint$Worker.run(JIoEndpoint.java:446)
23:37:01,975 ERROR [STDERR] at java.lang.Thread.run(Thread.java:595)
23:37:01,976 ERROR [STDERR] Caused by: java.net.SocketException: Broken pipe
23:37:01,976 ERROR [STDERR] at java.net.SocketOutputStream.socketWrite0(Native Method)
23:37:01,976 ERROR [STDERR] at java.net.SocketOutputStream.socketWrite(SocketOutputStream.java:92)
23:37:01,976 ERROR [STDERR] at java.net.SocketOutputStream.write(SocketOutputStream.java:136)
23:37:01,976 ERROR [STDERR] at org.apache.coyote.ajp.AjpProcessor$SocketOutputBuffer.doWrite(AjpProcessor.java:1210)
23:37:01,976 ERROR [STDERR] at org.apache.coyote.Response.doWrite(Response.java:560)
23:37:01,976 ERROR [STDERR] at org.apache.catalina.connector.OutputBuffer.realWriteBytes(OutputBuffer.java:353)
23:37:01,976 ERROR [STDERR] ... 30 more
This is 2 different stack traces from my client machine:
java.net.SocketException: Connection reset
ERROR: java.net.SocketException Connection reset
Executing GET for https://wsf-6.newco.com/ews/upload/20/deployStatus
Error while trying to get active job count. Error count = 808
at java.net.SocketInputStream.read(SocketInputStream.java:168)
at com.sun.net.ssl.internal.ssl.InputRecord.readFully(InputRecord.java:284)
at com.sun.net.ssl.internal.ssl.InputRecord.read(InputRecord.java:319)
at com.sun.net.ssl.internal.ssl.SSLSocketImpl.readRecord(SSLSocketImpl.java:720)
at com.sun.net.ssl.internal.ssl.SSLSocketImpl.performInitialHandshake(SSLSocketImpl.java:1025)
at com.sun.net.ssl.internal.ssl.SSLSocketImpl.writeRecord(SSLSocketImpl.java:619)
at com.sun.net.ssl.internal.ssl.AppOutputStream.write(AppOutputStream.java:59)
at java.io.BufferedOutputStream.flushBuffer(BufferedOutputStream.java:65)
at java.io.BufferedOutputStream.flush(BufferedOutputStream.java:123)
at org.apache.commons.httpclient.HttpConnection.flushRequestOutputStream(HttpConnection.java:827)
at org.apache.commons.httpclient.HttpMethodBase.writeRequest(HttpMethodBase.java:1975)
at org.apache.commons.httpclient.HttpMethodBase.execute(HttpMethodBase.java:993)
at org.apache.commons.httpclient.HttpMethodDirector.executeWithRetry(HttpMethodDirector.java:397)
at org.apache.commons.httpclient.HttpMethodDirector.executeMethod(HttpMethodDirector.java:170)
at org.apache.commons.httpclient.HttpClient.executeMethod(HttpClient.java:396)
at org.apache.commons.httpclient.HttpClient.executeMethod(HttpClient.java:324)
at com.convera.ews.ApplicationTransfer.executeGet(ApplicationTransfer.java:383)
at com.convera.ews.ApplicationTransfer.executeAction(ApplicationTransfer.java:205)
at com.convera.ews.UploadDeployTest.checkForClearQueue(UploadDeployTest.java:450)
at com.convera.ews.UploadDeployTest.testBasedOnItems(UploadDeployTest.java:329)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
at java.lang.reflect.Method.invoke(Method.java:585)
at junit.framework.TestCase.runTest(TestCase.java:154)
at junit.framework.TestCase.runBare(TestCase.java:127)
at junit.framework.TestResult$1.protect(TestResult.java:106)
at junit.framework.TestResult.runProtected(TestResult.java:124)
at junit.framework.TestResult.run(TestResult.java:109)
at junit.framework.TestCase.run(TestCase.java:118)
at junit.framework.TestSuite.runTest(TestSuite.java:208)
at junit.framework.TestSuite.run(TestSuite.java:203)
at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:478)
at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.run(RemoteTestRunner.java:344)
at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.main(RemoteTestRunner.java:196)
Other stack trace ................
java.net.ConnectException: Connection refused
06:43:55,325 INFO [main] (HttpMethodDirector.java:438) - I/O exception (java.net.ConnectException) caught when processing request: Connection refused
06:43:55,326 INFO [main] (HttpMethodDirector.java:444) - Retrying request
06:43:55,327 INFO [main] (HttpMethodDirector.java:438) - I/O exception (java.net.ConnectException) caught when processing request: Connection refused
06:43:55,327 INFO [main] (HttpMethodDirector.java:444) - Retrying request
06:43:55,328 INFO [main] (HttpMethodDirector.java:438) - I/O exception (java.net.ConnectException) caught when processing request: Connection refused
06:43:55,328 INFO [main] (HttpMethodDirector.java:444) - Retrying request
ERROR: java.net.ConnectException Connection refused
Executing GET for https://wsf-6.newco.com/ews/upload/20/deployStatus
Error while trying to get active job count. Error count = 799
at java.net.PlainSocketImpl.socketConnect(Native Method)
at java.net.PlainSocketImpl.doConnect(PlainSocketImpl.java:333)
at java.net.PlainSocketImpl.connectToAddress(PlainSocketImpl.java:195)
at java.net.PlainSocketImpl.connect(PlainSocketImpl.java:182)
at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:366)
at java.net.Socket.connect(Socket.java:507)
at com.sun.net.ssl.internal.ssl.SSLSocketImpl.connect(SSLSocketImpl.java:546)
at com.sun.net.ssl.internal.ssl.SSLSocketImpl.(SSLSocketImpl.java:390)
at com.sun.net.ssl.internal.ssl.SSLSocketFactoryImpl.createSocket(SSLSocketFactoryImpl.java:121)
at org.apache.commons.httpclient.protocol.SSLProtocolSocketFactory.createSocket(SSLProtocolSocketFactory.java:81)
at org.apache.commons.httpclient.protocol.SSLProtocolSocketFactory.createSocket(SSLProtocolSocketFactory.java:126)
at org.apache.commons.httpclient.HttpConnection.open(HttpConnection.java:706)
at org.apache.commons.httpclient.HttpMethodDirector.executeWithRetry(HttpMethodDirector.java:386)
at org.apache.commons.httpclient.HttpMethodDirector.executeMethod(HttpMethodDirector.java:170)
at org.apache.commons.httpclient.HttpClient.executeMethod(HttpClient.java:396)
at org.apache.commons.httpclient.HttpClient.executeMethod(HttpClient.java:324)
at com.convera.ews.ApplicationTransfer.executeGet(ApplicationTransfer.java:383)
at com.convera.ews.ApplicationTransfer.executeAction(ApplicationTransfer.java:205)
at com.convera.ews.UploadDeployTest.checkForClearQueue(UploadDeployTest.java:450)
at com.convera.ews.UploadDeployTest.testBasedOnItems(UploadDeployTest.java:329)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
at java.lang.reflect.Method.invoke(Method.java:585)
at junit.framework.TestCase.runTest(TestCase.java:154)
at junit.framework.TestCase.runBare(TestCase.java:127)
at junit.framework.TestResult$1.protect(TestResult.java:106)
at junit.framework.TestResult.runProtected(TestResult.java:124)
at junit.framework.TestResult.run(TestResult.java:109)
at junit.framework.TestCase.run(TestCase.java:118)
at junit.framework.TestSuite.runTest(TestSuite.java:208)
at junit.framework.TestSuite.run(TestSuite.java:203)
at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:478)
at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.run(RemoteTestRunner.java:344)
at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.main(RemoteTestRunner.java:196)
View the original post : http://www.jboss.com/index.html?module=bb&op=viewtopic&p=4113088#4113088
Reply to the post : http://www.jboss.com/index.html?module=bb&op=posting&mode=reply&p=4113088
More information about the jboss-user
mailing list