如何修复/避免java.io.IOException:套接字读取失败?

时间:2016-02-11 03:43:00

标签: java angularjs apache tomcat httpd.conf

我们有一个应用程序,它经常对servlet进行ajax调用。我们不一致地得到以下异常。

20:39:15.016 com.abc.xyzhome.util.XYZLog:XYZDashboardServlet::buildXYZDashboardRequest::Exception:
java.io.IOException: Socket read failed
        at org.apache.coyote.ajp.AjpProcessor.read(AjpProcessor.java:313)
        at org.apache.coyote.ajp.AjpProcessor.readMessage(AjpProcessor.java:364)
        at org.apache.coyote.ajp.AjpProcessor.receive(AjpProcessor.java:331)
        at org.apache.coyote.ajp.AbstractAjpProcessor.refillReadBuffer(AbstractAjpProcessor.java:664)
        at org.apache.coyote.ajp.AbstractAjpProcessor$SocketInputBuffer.doRead(AbstractAjpProcessor.java:1142)
        at org.apache.coyote.Request.doRead(Request.java:422)
        at org.apache.catalina.connector.InputBuffer.realReadBytes(InputBuffer.java:290)
        at org.apache.catalina.connector.InputBuffer.realReadChars(InputBuffer.java:353)
        at org.apache.tomcat.util.buf.CharChunk.substract(CharChunk.java:439)
        at org.apache.catalina.connector.InputBuffer.read(InputBuffer.java:416)
        at org.apache.catalina.connector.CoyoteReader.read(CoyoteReader.java:108)
        at org.apache.catalina.connector.CoyoteReader.readLine(CoyoteReader.java:163)
        at com.abc.xyzhome.XYZDashboardServlet.buildXYZDashboardRequest(XYZDashboardServlet.java:456)

当我们尝试从inputStream读取数据时,有时会发生异常。 PFB,发生此异常的地方。

        try {
             BufferedReader reader = request.getReader();
             while ((line = reader.readLine()) != null)
                jb.append(line);
        }  catch (IOException e) {
            e.printStackTrace();
        }

我们从BufferedReader获取HttpServletRequest个对象。异常发生在reader.readLine()

我们的应用程序托管在Tomcat 7.0.54中。 PFB,我们正在为客户提出的针对此特定请求的angularJS ajax调用。

$http({
      method: 'POST',
      url: 'XYZDashboard',
      headers: {'Content-Type': 'application/json'},
      data: {'xyzStatus':fav_value,'xyzRequestType':'getDataForXYZDashboard'},
      cache: false,
    }).success(function (data) 
    {
        //Some code here
    });

内容类型是JSON。请告诉我如何避免此异常。感谢。

编辑:我已尝试BufferedReader ready()检查流是否已准备好进行读取,但始终返回false。我在博客中读到,在Tomcat中,ready()总是返回false。请指教。

1 个答案:

答案 0 :(得分:-2)

将代码包装在抛出IOException的try / catch中

try {
    BufferedReader reader = request.getReader();
    while ((line = reader.readLine()) != null)
} catch (IOException e1) {
    e1.printStackTrace();
}