• Jmeter运行报错software caused connection abort:recv failed


    software caused connection abort: recv failed

    java.net.SocketException: Software caused connection abort: recv failed

    at java.net.SocketInputStream.socketRead0(Native Method)

    at java.net.SocketInputStream.read(SocketInputStream.java:129)

    产生这个异常的原因有多种方面,单就如 Software caused 所示,

    是由于程序编写的问题,而不是网络的问题引起的.

    已知会导致这种异常的一个场景如下:
    客户端和服务端建立tcp的短连接,每次客户端发送一次请求,
    服务端响应后关闭与客户端的连接.
    如果客户端在服务端关闭连接后,没有释放连接,继续试图发送请求和接收响应.
    这个时候就会出错 .

    这个时候客户端Socket的getOutputStream返回来的OutPutStream维护
    的是本地的连接状态,
    无法知道远程的服务端已经关闭了对应的InputStream和socket因此
    虽然调用了
    out.write(sendbuf, 0, sendbuf.length);
    方法,但是实际上服务端并没有接收到客户端的请求信息.
    因为没有抛出异常,因此造成了误以为客户端请求发送成功的假象.

    接下来调用InputStream的in.read(header, 0, 14);方法.
    因为这次要读取服务端的信息,因此产生了
    Software caused connection abort: recv failed的异常

    总结产生原因,在服务端/客户端单方面关闭连接的情况下,另一方依然以为
    tcp连接仍然建立,试图读取对方的响应数据,导致出现
    Software caused connection abort: recv failed的异常. 

    因此在receive数据之前,要先判断连接状态.
    通过inputstream的available()方法来判断,是否有响应结果.
    如果available()的返回值为0,说明没有响应数据,可能是对方已经断开连接,
    如果available()的返回值大于0,说明有响应数据.
    另外值得注意的是available()返回的值是非堵塞的,可以被多个线程访问

    在对方释放连接后,也要释放本地的连接.

     
     
    Jmeter并发数量达到一定数量(超过500)后,报software caused connection abort:recv failed(软件导致连接中止:接收失败)
    这种情况应该怎样去定位问题? 

    如何定位问题:

    1、先看硬件资源

    2、再看服务器连接数以及连接状态(服务器不是无限制连接的,都有限制的)

    (如ngix1.14版本限制并发500、)

  • 相关阅读:
    我查询的问题点
    更改hosts操作
    日常有用的网站
    加入到java后台开发
    知识点收藏
    Mac操作技巧
    设置自己的APP能打开文件(在其他应用中打开显示自己的应用)
    思维不要留在框里
    X RMAN Crosscheck后delete obsolete遇到RMAN-06091的解决
    X No standby redo logfiles created for thread 1
  • 原文地址:https://www.cnblogs.com/xly22/p/11425475.html
Copyright © 2020-2023  润新知