2012-07-19 26 views
6

के बाद टोमकैट सर्वलेट मैपिंग त्रुटि हमने टॉमकैट संस्करण में सर्वलेट 3.0 AsyncContext को लागू किया है: 7.0.23।टूटी हुई पाइप त्रुटि

यह RHEL 6.1 using OpenJDK version 1.6.0_24,64-bit सर्वर

अनुप्रयोग में runing है अधिकांश भाग के लिए ठीक काम कर रहा है। जब नेटवर्क में कुछ परेशानी होती है, तो सर्वर से अद्यतन क्लाइंट तक पहुंचने में सक्षम नहीं है क्योंकि "ClientAbortException: java.net.SocketException: Broken pipe" अपवाद है। जो पकड़ा और अनदेखा किया जाता है।

इस लाइन में होता है,

asyncContext.getResponse().getWriter().println(updateStr); 

के बाद इस बिलाव पागल हो जाता है और अप्रत्याशित सर्वलेट्स करने के लिए URL मार्ग है। उदाहरण के लिए सत्र प्रबंधक नामक सर्वलेट को मैपिंग/क्वेरी के साथ, URL mysite.com/index.html सत्र प्रबंधक सेवा में भेजा गया है। केवल टमाटर को पुनरारंभ करने से समस्या हल हो जाती है।

कोई संकेतक यह क्यों हो रहा है और इसे कैसे हल करें?

बस अधिक डेटा जोड़ने के लिए, निम्नलिखित अपवाद का स्टैक ट्रेस है।

ClientAbortException: java.net.SocketException: Broken pipe 
    at org.apache.catalina.connector.OutputBuffer.doFlush(OutputBuffer.java:346) 
    at org.apache.catalina.connector.OutputBuffer.flush(OutputBuffer.java:306) 
    at org.apache.catalina.connector.Response.flushBuffer(Response.java:568) 
    at org.apache.catalina.connector.ResponseFacade.flushBuffer(ResponseFacade.java:307) 
    at com.management.TestHandler$TestInfo.statusUpdate(TestHandler.java:638) 
    at com.chakra.ipbtt.TestObject.publish(TestObject.java:1626) 
    at com.chakra.ipbtt.TestObject.handlePublish(TestObject.java:1421) 
    at com.chakra.ipbtt.TestObject.executeCommand(TestObject.java:1371) 
    at com.chakra.ipbtt.TestObject.executeCommand(TestObject.java:1388) 
    at com.chakra.ipbtt.TestObject.executeCommand(TestObject.java:1388) 
    at com.chakra.ipbtt.TestObject.executeCommand(TestObject.java:1388) 
    at com.chakra.ipbtt.TestObject.executeCommand(TestObject.java:1388) 
    at com.chakra.ipbtt.TestObject.executeCommand(TestObject.java:1388) 
    at com.chakra.ipbtt.TestObject.executeTest(TestObject.java:1791) 
    at com.management.TestHandler.executeTest(TestHandler.java:420) 
    at com.management.TestHandler.handleNewTest(TestHandler.java:222) 
    at com.management.TestMgr.processRequest(TestMgr.java:71) 
    at com.management.TestMgr.doPost(TestMgr.java:105) 
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:641) 
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:722) 
    at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:305) 
    at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:210) 
    at org.apache.catalina.core.ApplicationDispatcher.invoke(ApplicationDispatcher.java:690) 
    at org.apache.catalina.core.ApplicationDispatcher.processRequest(ApplicationDispatcher.java:477) 
    at org.apache.catalina.core.ApplicationDispatcher.doForward(ApplicationDispatcher.java:402) 
    at org.apache.catalina.core.ApplicationDispatcher.forward(ApplicationDispatcher.java:329) 
    at com.management.SessionMgr.processRequest(SessionMgr.java:131) 
    at com.management.SessionMgr.doPost(SessionMgr.java:164) 
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:641) 
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:722) 
    at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:305) 
    at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:210) 
    at com.management.SessionsFilter.doFilter(SessionsFilter.java:127) 

    at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:243) 
    at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:210) 
    at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:225) 
    at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:123) 
    at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:472) 
    at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:168) 
    at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:98) 
    at org.apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.java:927) 
    at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:118) 
    at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:407) 
    at org.apache.coyote.http11.AbstractHttp11Processor.process(AbstractHttp11Processor.java:1001) 
    at org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:585) 
    at org.apache.tomcat.util.net.JIoEndpoint$SocketProcessor.run(JIoEndpoint.java:310) 
    at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1110) 
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:603) 
    at java.lang.Thread.run(Thread.java:636) 

Caused by: java.net.SocketException: Broken pipe 
    at java.net.SocketOutputStream.socketWrite0(Native Method) 
    at java.net.SocketOutputStream.socketWrite(SocketOutputStream.java:109) 
    at java.net.SocketOutputStream.write(SocketOutputStream.java:153) 
    at org.apache.coyote.http11.InternalOutputBuffer.realWriteBytes(InternalOutputBuffer.java:215) 
    at org.apache.tomcat.util.buf.ByteChunk.flushBuffer(ByteChunk.java:462) 
    at org.apache.coyote.http11.InternalOutputBuffer.flush(InternalOutputBuffer.java:119) 
    at org.apache.coyote.http11.AbstractHttp11Processor.action(AbstractHttp11Processor.java:789) 
    at org.apache.coyote.Response.action(Response.java:174) 
    at org.apache.catalina.connector.OutputBuffer.doFlush(OutputBuffer.java:341) 
    ... 48 more` 
+1

हाय, क्या आपको कोई समाधान या कारण मिला? –

उत्तर

0

यह टोमकैट के किनारे एक बग की तरह लगता है।

सबसे पहले, मैं अपाचे टॉमकैट 7.0 को अपडेट करने का प्रयास करूंगा। ।

दूसरा, मैं जावा 6u पर अपडेट करने का प्रयास करता हूं।

संबंधित मुद्दे