zoukankan      html  css  js  c++  java
  • Connection reset by peer

    Connection reset by peer

    如:
    {{{
    Successfully uninstalled SFX driver packages.
    2019-11-13 10:08:14,419 INFO Relay power off/on 192.168.35.125
    Traceback (most recent call last):
      File "AW_AsyncMultiLbaRangesWSPC_LongTime.py", line 95, in <module>
        caseIns.run()
      File "AW_AsyncMultiLbaRangesWSPC_LongTime.py", line 80, in run
        pcexe.safePC(ioexe=ioexe)
      File "/home/tcnsh/sw_qualification/Samanea/Samanea_Lib/PowerCycle.py", line 307, in safePC
        self.power(relayIP, pwoffCmd, statusCmd, relayMode, tryLoops, 0)
      File "/home/tcnsh/sw_qualification/Samanea/Samanea_Lib/PowerCycle.py", line 121, in power
        status = int(chr(self.relayRead(22, relay)[12]))
      File "/home/tcnsh/sw_qualification/Samanea/Samanea_Lib/PowerCycle.py", line 93, in relayRead
        chunk = relay.recv(min(readnum - bytes_recd, 2048))
    ConnectionResetError: [Errno 104] Connection reset by peer
    }}}

    @@baidu:https:https://blog.csdn.net/xc_zhou/article/details/80950753
    1.如果一端的Socket被关闭(或主动关闭,或因为异常退出而引起的关闭),另一端仍发送数据,发送的第一个数据包引发该异常(Connection reset by peer)。
    Socket默认连接60秒,60秒之内没有进行心跳交互,即读写数据,就会自动关闭连接。
    2.一端退出,但退出时并未关闭该连接,另一端如果在从连接中读数据则抛出该异常(Connection reset)。
    Connection reset by peer的常见原因:
    1)服务器的并发连接数超过了其承载量,服务器会将其中的一些连接关闭;
    如果知道实际连接服务器的并发客户数没有超过服务器的承载量,则有可能是中了病毒或者木马,引起网络流量异常。可以使用netstat -an 查看网络连接情况。
    2)客户关掉了浏览器,而服务器还在给客户端发送数据;
    3)浏览器按了stop;
    这两种情况一般不会影响服务器。但是如果对异常信息没有特别处理,有可能在服务器的日志文件中,重复出现该异常,造成服务器日志文件过大,影响服务器的运行。可以对引起异常的部分,使用try…catch捕获该异常,然后不输出或者只输出一句提示信息,避免使用e.printStackTrace(); 输出全部异常信息。
    4)防火墙的问题;
    如果网络连接通过防火墙,而防火墙一般都会有超时机制,在网络连接长时间不传输数据时,会关闭这个TCP会话,关闭后在读写就会导致异常。如果关闭防火墙,解决了问题,需要重新配置防火墙,或者自己编写程序实现TCP的长连接。实现TCP的长连接,需要自己定义心跳协议,每隔一段时间,发送一次心跳协议,双方维持连接。
    5)JSP的buffer问题;
    JSP页面缺省缓存为8k,当JSP页面数据比较大的时候,有可能JSP没有完全传递给浏览器。这时可以适当调整buffer的大小。

    第1个异常是java.net.BindException:Address already in use:JVM_Bind.
    该异常发生在服务器端进行new ServerSocket(port) (port是一个0,65536的整型值)操作时。异常的原因是以为与port一样的一个端口已经被启动,并进行监听。此时用netstat -an命令,可以看到一个Listending状态的端口。只需要找一个没有被占用的端口就能解决这个问题。
     
    第2个异常是java.net.ConnectException:Connection refused:connect.
    该异常发生在客户端进行new Socket(ip,port)操作时,该异常发生的原因是或者具有ip地址的机器不能找到(也就是说从当前机器不存在到指定ip路由),或者是该ip存在,但找不到指定的端口进行监听。出现该问题,首先检查客户端的ip和port是否写错了,如果正确则从客户端ping一下服务器,看是否能ping通,如果能ping通(服务器端把ping禁掉则需要另外的方法),则看在服务器端的监听指定端口的程序是否启动,这个肯定能解决问题。
     
    第3个异常是java.net.SocketException:Socket is closed.
    该异常在客户端和服务器均可能发生。异常的原因是己方主动关闭了连接后(调用了Socket的close方法)再对网络进行读写操作。
     
    第4个异常是java.net.SocketException:(Connection reset或者Connection reset by peer:Socket write error).
    该异常在客户端和服务器端均有可能发生,引起该异常的原因有两个,第一个就是如果一端的Socket被关闭(或主动关闭或者因为异常退出而引起的关闭),另一端仍发送数据,发送的第一个数据包引发该异常(connection reset by peer)。另一个是一端退出,但退出时并未关闭该连接,另一端如果在从连接中读取数据则抛出该异常(connection reset)。简单地说就是在连接断开后的读和写操作引起的。
    在第一种情况中(也就是抛出SocketException:Connect reset by peer:Socket write error后),如果再继续写数据则抛出该异常。前两个异常的解决方法是首先确保程序退出前关闭所有的网络连接,其次是要检测对方的关闭连接操作,发现对方关闭连接后自己也要关闭该连接。
     
    第5个异常是java.net.SocketException:Broken pipe.
    该异常在客户端和服务器端均有可能发生。
     
  • 相关阅读:
    Spring @Async开启异步任务
    Spring中@Async用法总结
    分布式任务调度平台XXL-JOB
    异常的概念和Java异常体系结构
    Java中主线程如何捕获子线程抛出的异常
    java主线程捕获子线程中的异常
    springboot线程池@Async的使用和扩展
    全面理解Java内存模型(JMM)及volatile关键字
    C++异常处理入门
    VC6下深入理解new[]和delete[](在多线程下new和delete的时候,必须选择上多线程库,不然可能造成进程崩溃)
  • 原文地址:https://www.cnblogs.com/qinsoo/p/11883091.html
Copyright © 2011-2022 走看看