【问题标题】:I m getting java.net.SocketException: Connection reset exception while running a load test using Jmeter我得到 java.net.SocketException: Connection reset exception while running a load test using Jmeter
【发布时间】:2024-01-23 16:49:01
【问题描述】:

我正在我的应用程序的登录页面上为 100 个用户中的 100 个用户运行负载测试 20 个用户正在通过其余 80 个用户我得到以下异常,请帮助我修复

java.net.SocketException: Connection reset
    at java.net.SocketInputStream.read(Unknown Source)
    at java.net.SocketInputStream.read(Unknown Source)
    at org.apache.http.impl.io.AbstractSessionInputBuffer.fillBuffer(AbstractSessionInputBuffer.java:166)
    at org.apache.http.impl.io.SocketInputBuffer.fillBuffer(SocketInputBuffer.java:90)
    at org.apache.http.impl.io.AbstractSessionInputBuffer.readLine(AbstractSessionInputBuffer.java:281)
    at org.apache.http.impl.conn.DefaultHttpResponseParser.parseHead(DefaultHttpResponseParser.java:92)
    at org.apache.http.impl.conn.DefaultHttpResponseParser.parseHead(DefaultHttpResponseParser.java:61)
    at org.apache.http.impl.io.AbstractMessageParser.parse(AbstractMessageParser.java:254)
    at org.apache.http.impl.AbstractHttpClientConnection.receiveResponseHeader(AbstractHttpClientConnection.java:289)
    at org.apache.http.impl.conn.DefaultClientConnection.receiveResponseHeader(DefaultClientConnection.java:252)
    at org.apache.http.impl.conn.ManagedClientConnectionImpl.receiveResponseHeader(ManagedClientConnectionImpl.java:191)
    at org.apache.http.protocol.HttpRequestExecutor.doReceiveResponse(HttpRequestExecutor.java:300)
    at org.apache.http.protocol.HttpRequestExecutor.execute(HttpRequestExecutor.java:127)
    at org.apache.http.impl.client.DefaultRequestDirector.tryExecute(DefaultRequestDirector.java:715)
    at org.apache.http.impl.client.DefaultRequestDirector.execute(DefaultRequestDirector.java:520)
    at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:906)
    at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:805)
    at org.apache.jmeter.protocol.http.sampler.HTTPHC4Impl.executeRequest(HTTPHC4Impl.java:505)
    at org.apache.jmeter.protocol.http.sampler.HTTPHC4Impl.sample(HTTPHC4Impl.java:328)
    at org.apache.jmeter.protocol.http.sampler.HTTPSamplerProxy.sample(HTTPSamplerProxy.java:74)
    at org.apache.jmeter.protocol.http.sampler.HTTPSamplerBase.sample(HTTPSamplerBase.java:1141)
    at org.apache.jmeter.protocol.http.sampler.HTTPSamplerBase.sample(HTTPSamplerBase.java:1130)
    at org.apache.jmeter.threads.JMeterThread.process_sampler(JMeterThread.java:431)
    at org.apache.jmeter.threads.JMeterThread.run(JMeterThread.java:258)
    at java.lang.Thread.run(Unknown Source)

【问题讨论】:

标签: jmeter performance-testing socketexception


【解决方案1】:

我相信您正面临Connection Reset since JMeter 2.10 ? JMeter wiki 页面中描述的问题。如果您完全确定您的被测应用程序的行为是正确的,并且不需要在后端进行任何调整或调整,您可以将 JMeter 配置为重试拒绝的连接并检查陈旧的连接:

  1. 将所有 HTTP 请求采样器的“实施”更改为 HttpClient4。最简单的方法是使用HTTP Request Defaults 配置元素。
  2. 在您安装的 JMeter 的 /bin 文件夹下的 user.properties 文件中添加以下属性:

    httpclient4.retrycount=1
    hc.parameters.file=hc.parameters
    
  3. 将下一行添加到 hc.parameters 文件(相同位置,JMeter 的 /bin 文件夹)

    http.connection.stalecheck$Boolean=true
    
  4. 重新启动 JMeter。

您的“连接重置”问题应该会消失。

【讨论】:

  • 嗨 Dmitri,我也遇到了上述问题。我已经完成了您提到的步骤,更新了 Java 1.8 并检查了请求是否正确/不正确,但我仍然遇到了同样的错误。请帮我解决。
  • 它与 JMeter 3.3 相关吗?