在调试上传文件的脚本并试运行时,发现并发数超过一定数量后,总会报“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个并发,但是再多的并发,改大这个值也无济于事了。