在调试上传文件的脚本并试运行时,发现并发数超过一定数量后,总会报“Non HTTP response code: java.net.SocketException/Non HTTP response message: Socket closed”的错误:

问题原因:在JMeter下,发送http 请求时,一般都是默认选择了use keepAlive,这个是连接协议,但其配置JMeter.properties中的时间设置默认却是注销的,也是是说,不会等待,一旦连接空闲,则立马断开了,导致我们压测中出现了事务失败的情形。
解决:修改jmeter.properties文件中 httpclient4.idletimeout,设置成自己觉得合理的时间,一般可设置成10-60s(表示连接空闲10s后才会断开),注意单位是ms。
打开jmeter.properties,修改如下:
|
Plain Text |
注意:修改执行机的JMeter目录下的这个文件,这个值并不是越大越好,一般都在60秒内。
实际使用中证明,这个值为10秒时,可以支持100个并发,改变到30秒,可以支持150个并发,但是再多的并发,改大这个值也无济于事了。
在JMeter测试中遇到并发请求时出现'Non HTTP response code: java.net.SocketException'错误,原因是JMeter默认的keepAlive设置与httpclient4.idletimeout配置不匹配。解决方法是修改jmeter.properties文件,将httpclient4.idletimeout设为10-60s以避免过早关闭连接。实践证明,适当调整此值可以提高并发支持能力。
6205

被折叠的 条评论
为什么被折叠?



