Connection reset by peer: socket write error错误分析及解决

  

Connection reset by peer: socket write error错误分析及解决

问题描述:
java.net.SocketException: Connection reset by peer.
        at jrockit.net.SocketNativeIO.write(IIIZ)I(Unknown Source)
        at jrockit.net.SocketNativeIO.write(III)I(Unknown Source)
        at jrockit.io.NativeIO.write(Ljava/io/FileDescriptor;II)I(Unknown Source
)
....

Connection reset by peer: socket write error错误分析:

常出现的Connection reset by peer: 原因可能是多方面的,不过更常见的原因是:
①:服务器的并发连接数超过了其承载量,服务器会将其中一些连接Down掉;
②:客户关掉了浏览器,而服务器还在给客户端发送数据;
③:浏览器端按了Stop

通常原因为:远程主机上对等方应用程序突然停止运行,或远程主机重新启动,或远程主机在远程方套接字上使用了“强制”关闭 (参见setsockopt(SO_LINGER))。另外,在一个或多个操作正在进行时,如果连接因“keep-alive”活动检测到一个失败而中 断,也可能导致此错误。此时,正在进行的操作以错误码WSAENETRESET失败返回,后续操作将失败返回错误码WSAECONNRESET。
但是如果频繁出现,就表示很 多客户端连接到Apache服务器的响应时间太长了,可能是网络的问题或者服务器性能问题。


网友分析:

要从一个被屏蔽的网站上下载一些东西,于是写了一个Servlet,将它传到了一台境外的服务器上.
让这台服务器去下载指定的资源,然后再回传给我.相当于一个代理吧.


JAVA code
public void doGet(HttpServletRequest request, HttpServletResponse response)            throws ServletException, IOException {
        String url = "http://www.silk163.com"; //得到要下载的减肥资源的URL.
        if (!StringUtils.isNullOrEmpty(url)) {
            System.out.println(url);
            URL u = new URL(url);
            URLConnection conn = u.openConnection();
            try { ///把响应头设置成一样的.
                for (Map.Entry<String, List<String>> m : conn.getHeaderFields()                        .entrySet()) {
                   if (m != null && m.getKey() != null && m.getValue() != null                            && m.getValue().size() > 0) {

                        response.setHeader(m.getKey(), m.getValue().get(0));                    }                }
            } catch (Exception e) {
               // TODO: handle exception
                e.printStackTrace();
                CommonLog.log.warn(e);
            }
            InputStream in = conn.getInputStream(); //从 connection得到inputstream            OutputStream out = response.getOutputStream(); //得到向客户端的输出流
            try {
                IOUtils
                        .wrITe(conn.getInputStream(), response                                .getOutputStream()); //写数据.

            } catch (Exception e) {

                e.printStackTrace();
                // TODO: handle exception
                CommonLog.log.warn(e);
                if (in != null) {
                    in.close();
                }
                if (out != null) {
                    out.close();
                }            }        }    }


IOUtils.wrITe()代码如下:


JAVA code
    /**     * 从input里面读取数据然后写入output,读完后自动关闭流。     * @param input inputStream     * @param output outputStream     * */    public static void write(InputStream input, OutputStream output)            throws IOException {        write(input,output,true);    }    /**     * 自动从inputstream里面读数据,然后写到outputstream里面去。     * @param input inputstream     * @param output outputstream     * @param close 读完后是否自动关闭流。     * */    public static void write(InputStream input, OutputStream output,boolean close)            throws IOException {        byte[] b = new byte[1024];        int len = input.read(b);        while (len != -1) {            output.wrITe(b, 0, len);            len = input.read(b);        }                output.flush();        if (close) {            input.close();                output.close();        }    }

将程序传到服务器上以后,在服务器上访问
http://localhost:8080/test/down?url=http://www.silk163.com/jianfei.zip

可以下载成功.

但是当远程访问的时候,就会出现
JAVA.NET.SocketException: Connection reset by peer: socket wrITe error

假设服务器IP是2.2.2.2吧.

访问
http://2.2.2.2:8080/test/down?url=http://www.xxx.com/z.zip
就会出现上面的那个错误.
注意,我并没有关闭浏览器或者按停止按钮.只要一打上那个地址就会出错.


错误发生在:


JAVA code
output.wrITe(b, 0, len);//执行这行代码的时候.

具体的错误信息如下:

 

JAVA code
ClientAbortException:  java.net.SocketException: Connection reset by peer: socket write error    at org.apache.catalina.connector.OutputBuffer.realWriteBytes(OutputBuffer.java:366)    at org.apache.tomcat.util.buf.ByteChunk.flushBuffer(ByteChunk.java:432)    at org.apache.tomcat.util.buf.ByteChunk.append(ByteChunk.java:347)    at org.apache.catalina.connector.OutputBuffer.writeBytes(OutputBuffer.java:392)    at org.apache.catalina.connector.OutputBuffer.write(OutputBuffer.java:381)    at org.apache.catalina.connector.CoyoteOutputStream.write(CoyoteOutputStream.java:89)    at com.joejoe.utils.IOUtils.write(IOUtils.java:62)    at com.joejoe.utils.IOUtils.wrITe(IOUtils.java:48)    at com.tqsoft.wdys.other.getMegavideo.doGet(getMegavideo.java:79)    at javax.servlet.http.HttpServlet.service(HttpServlet.java:627)    at javax.servlet.http.HttpServlet.service(HttpServlet.java:729)    at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:269)    at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:188)    at com.joejoe.utils.WEB.CharSetFilter.doFilter(CharSetFilter.java:39)    at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:215)    at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:188)    at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:213)    at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:172)    at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:127)    at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:117)    at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:108)    at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:174)    at org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:875)    at org.apache.coyote.http11.Http11BaseProtocol$Http11ConnectionHandler.processConnection(Http11BASEProtocol.java:665)    at org.apache.tomcat.util.net.PoolTcpEndpoint.processSocket(PoolTcpEndpoint.java:528)    at org.apache.tomcat.util.net.LeaderFollowerWorkerThread.runIt(LeaderFollowerWorkerThread.java:81)    at org.apache.tomcat.util.threads.ThreadPool$ControlRunnable.run(ThreadPool.java:689)    at java.lang.Thread.run(Unknown Source)Caused by: java.net.SocketException: Connection reset by peer: socket write error    at java.net.SocketOutputStream.socketWrite0(Native Method)    at java.net.SocketOutputStream.socketWrITe(Unknown Source)    at JAVA.NET.SocketOutputStream.write(Unknown Source)    at org.apache.coyote.http11.InternalOutputBuffer.realWriteBytes(InternalOutputBuffer.java:750)    at org.apache.tomcat.util.buf.ByteChunk.flushBuffer(ByteChunk.java:432)    at org.apache.tomcat.util.buf.ByteChunk.append(ByteChunk.java:347)    at org.apache.coyote.http11.InternalOutputBuffer$OutputStreamOutputBuffer.doWrite(InternalOutputBuffer.java:773)    at org.apache.coyote.http11.filters.IdentityOutputFilter.doWrite(IdentityOutputFilter.java:118)    at org.apache.coyote.http11.InternalOutputBuffer.doWrite(InternalOutputBuffer.java:583)    at org.apache.coyote.Response.doWrite(Response.java:560)    at org.apache.catalina.connector.OutputBuffer.realWrITeBytes(OutputBuffer.JAVA:361)    ... 27 more

请问如何解决.谢谢.

 

编 程论坛 5 个网友回答: 说是这原因
存在的连接被远程主机强制关闭。通常原因为:远程主机上对等方应用程序突然停止运行,或远程主机重新启动,或远程主机在远程方套接字上使用了“强制”关闭 (参见setsockopt(SO_LINGER))。另外,在一个或多个操作正在进行时,如果连接因“keep-alive”活动检测到一个失败而中 断,也可能导致此错误。此时,正在进行的操作以错误码WSAENETRESET失败返回,后续操作将失败返回错误码WSAECONNRESET。      .

 

编 程论坛 6 个网友回答: ClientAbortException: JAVA.NET.SocketException: Connection reset by peer: socket wrITe error的原因是由于处理http连接时,正在输出内容时,用户关闭了IE,会出现一个"ClientAbortException",属于I/O处理 中出现的一个异常,应用服务器应该会捕捉。
Connection reset by peer的原因:
经常出现的Connection reset by peer: 原因可能是多方面的,不过更常见的原因是:
①:服务器的并发连接数超过了其承载量,服务器会将其中一些连接Down掉;
②:客户关掉了浏览器,而服务器还在给客户端发送数据;
③:浏览器端按了Stop
很多人都说是客户端造成的,没有办法控制,是个比较郁闷的问题。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
引用\[1\]中提到,"Connection reset by peer: socket write error"是一个常见的错误,可能有多种原因。其中一些常见的原因包括服务器的并发连接数超过了其承载量,导致服务器关闭一些连接;客户端关闭浏览器,但服务器仍在发送数据;或者浏览器按下了停止按钮。这个错误也可能是由于远程主机上的应用程序突然停止运行、远程主机重新启动,或者远程主机在远程套接字上使用了"强制"关闭等原因引起的。此外,如果连接因为"keep-alive"活动检测到失败而中断,也可能导致此错误。\[1\] 引用\[2\]中描述了一个具体的问题,即在一个文件上传接口中,当参数校验失败或者文件已经存在时,客户端会偶尔出现"connection reset by peer, socket write error"的错误。经过猜测和重现,发现只有在上传较大的文件且参数校验失败或者重复上传时才会出现这个错误。作者猜测是因为当客户端上传大文件时,服务端在接收到HTTP头部后开始进行参数校验,并在不符合条件时直接返回响应,关闭输出流的同时也关闭了输入流。通过在服务端改动,先调用request.getInputStream().skip(request.getContentLength)再返回响应,问题得到解决。作者还通过抓包发现,服务端已经返回了错误码信息,但客户端可能没有接收到响应,导致报错。\[2\] 根据引用\[3\]中的说明,HTTP规范只是建议在关闭连接时应该正常关闭传输连接,但没有具体说明如何操作。在关闭连接时,双方应该各自关闭自己的输出信道,并等待对方关闭输出信道,这样连接才能完全关闭,避免出现"connection reset"错误。然而,现实中无法保证双方都按照这个约定操作。因此,除了自己关闭输出信道外,还需要周期性检查输入信道的状态,如果一段时间内对方没有关闭输出信道,就需要强制结束以节省时间。\[3\] 综上所述,"Connection reset by peer: socket write error"错误可能由多种原因引起,包括服务器并发连接数超载、客户端关闭浏览器浏览器按下停止按钮等。在具体问题中,可能是由于上传较大的文件且参数校验失败或者重复上传导致的。为了解决这个问题,可以在服务端改动,先调用request.getInputStream().skip(request.getContentLength)再返回响应。此外,根据HTTP规范的建议,双方应该各自关闭输出信道,并周期性检查输入信道的状态,以避免"connection reset"错误的发生。 #### 引用[.reference_title] - *1* [Connection reset by peer: socket write error错误分析解决](https://blog.csdn.net/XingKong22star/article/details/39203611)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* *3* [分析connection reset by peer, socket write error错误原因](https://blog.csdn.net/xiaoxiangzi520/article/details/127975743)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值