字节8年经验之谈 —— Jmeter自动化性能测试常见问题!_jmeter 设置超时时间

jmeter 发送请求后返回java.net.SocketException: Connection reset

这表明是测试服务器有问题,可以去页面验证下。有可能是要配置客户端的设置,如上面的工具运行设置。

java.net.SocketException: Socket closed

step1:

在 http 请求里面找到高级 implementation 选择 httpclient 4,connect设置为15000-300000毫秒。

step2:

在 jmeter 安装目录的 bin 目录下,找到 jmeter.properties 并打开。打开425行的注释,值设置为1:

httpclient4.retrycount = 1
  httpclient4.idletimeout=<time in 1000 ms>
  java.lang.OutOfMemoryError: Java heap space

原因:

观察运行 jmeter 机器的内存,占用较高,超过了 jmeter 设置的内存上限。

解决方案:

修改 jmeter 配置文件,调整内存可用的范围服务器

修改/bin/jmeter.bat文件:找到这2行

set HEAP=-Xms256m -Xmx256m
  set NEW=-XX:NewSize=128m -XX:MaxNewSize=128m

改成:

set HEAP=-Xms1024m –Xmx2048m(最大值不能超过系统内存的1/2)
  set NEW=-XX:NewSize=128m -XX:MaxNewSize=512m网络
  { “_t” : “StringResultObject”, “status” : 1030, “message” : “服务器发生错误”, “data” : null, “isSuccess” : false }

如遇到上面请求返回的reponse, 就要首先去服务器端的日志,通过日志来定位问题

Failed to initialise remote engine java.rmi.ConnectException: Connection refused to host:

原因:

分布式测试时,server 和 agent 之间的链接有问题。单个机器排查后,发现是某个 agent 机器安装了多个网卡,rmi 远程的时候找的是虚拟机的网卡,致使链接失败。

解决方案:

禁掉不使用的虚拟机网卡,测试以后再恢复

java.lang.OutOfMemoryError: Java heap space

原因

jmeter 是一个纯 java 开发的工具,内存由 java 虚拟机 JVM 管理,当内存回收不及时,堆内存不足时,就会报内存溢出错误。

概念补充:

**内存泄露:**应用使用资源之后没有及时释放,导致应用内存中持有了不需要的资源。

**内存溢出:**应用的内存已经不能满足正常使用了,堆栈已经达到系统设置的最大值,进而导致崩溃。

通常都是由于内存泄露导致堆栈内存不断增大,从而引发内存溢出。对 jmeter 而言也是如此,jmeter 测试过程中,如果内存溢出的话,一般会出现上面的提示:java.lang.OutOfMemoryError: Java heap space意思就是堆内存溢出,不够用了

解决方法:

知道了报错出现的原因是因为堆内存大小不足引起的,自然而然就会想到内存溢出的解决方法:调整堆内存大小。

步骤(以Windows系统为例,Linux系统类似):

1. 打开jmeter.bat文件,按关键字“HEAP”搜索,把原来的配置改为如下:修改前:

if not defined HEAP (
  rem See the unix startup file for the rationale of the following parameters,
  rem including some tuning recommendations
  set HEAP=-Xms1g -Xmx1g -XX:MaxMetaspaceSize=256m
  )
  )

修改后:

if not defined HEAP (
  rem See the unix startup file for the rationale of the following parameters,
  rem including some tuning recommendations
  set HEAP=-Xms512m -Xmx4000m
  set NEW=-XX:NewSize=256m -XX:MaxNewSize=512m
  )
  set HEAP=-Xms512m -Xmx4000m:调整堆内存的大小
  set NEW=-XX:NewSize=256m -XX:MaxNewSize=512m:调整堆内存中新生带的大小

PS:

这个值不是越大越好,要根据压测使用的机器而定,一般而言,堆内存的最大值不要超过物理内存的一半,否则容易导致 jmeter 运行变慢、卡顿甚至内存溢出(因为java本身的垃圾回收机制是动态分配内存,调整的时候其本身会占用很多内存),NEW分配的内存,不宜太大。

1. 修改完成后保存,重启JMeter,即可生效。

三、小结

1. 这种修改堆大小的方法只适用一部分情况,并不是万能的,当需要模拟的线程数较大时,就需要根据具体情况采用分布式压测的方式了。

2. 命令行运行 jmeter 时,一定要禁用“查看结果树”、“聚合报告”等监听器,因为真的真的真的很消耗内存。

3. 磁盘监控工具有iostat & htop。

4. 网络监控工具有iftop。

5. 查看网络连接情况可以使用netstat -n | find /I “established” /c。


最后感谢每一个认真阅读我文章的人,看着粉丝一路的上涨和关注,礼尚往来总是要有的,虽然不是什么很值钱的东西,如果你用得到的话可以直接拿走!

软件测试面试文档

我们学习必然是为了找到高薪的工作,下面这些面试题是来自阿里、腾讯、字节等一线互联网大厂最新的面试资料,并且有字节大佬给出了权威的解答,刷完这一套面试资料相信大家都能找到满意的工作。

  • 17
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值