欢迎您访问 最编程 本站为您分享编程语言代码,编程技术文章!
您现在的位置是: 首页

jemeter 1S 启动 600 线程 jmeter 设置 5000 线程

最编程 2024-04-29 16:20:04
...


一.报错内容:

jemeter 1S起600个线程 jmeter设置5000线程_jemeter 1S起600个线程

ava.lang.OutOfMemoryError: Java heap space意思就是堆内存溢出,不够用了

版本:jmeter5

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

通常都是由于内存泄露导致堆栈内存不断增大,从而引发内存溢出。

 用JMeter压测,有时候当模拟并发请求较大或者脚本运行时间较长时,JMeter会停止,报OOM(内存溢出)错误。

二.解决方案

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

方案1

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 -Xmx4096m set NEW=-XX:NewSize=256m -XX:MaxNewSize=512m )

set HEAP=-Xms512m -Xmx4000m:调整堆内存的大小 set NEW=-XX:NewSize=256m -XX:MaxNewSize=512m:调整堆内存中新生带的大小

注意:

这个值不是越大越好,要根据压测使用的机器而定,一般而言,堆内存的最大值不要超过物理内存的一半,否则容易导致jmeter运行变慢、

卡顿甚至内存溢出(因为java本身的垃圾回收机制是动态分配内存,调整的时候其本身会占用很多内存),NEW分配的内存,不宜太大。

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

方案2

linux可以这样写:JVM_ARGS="-Xms1024m -Xmx1024m"  (JVM_ARGS代表启动JMeter时要使用的Java选项。这些将最后添加到java命令),以下是举例

打开jmeter.bat文件

修改前:

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=-Xms12g -Xmx12g -XX:MaxMetaspaceSize=1g )

-XX:MaxPermSize=256M:最大类加载内存池大小

方案3

直接命令

JVM_ARGS="-Xms12g -Xmx12g" jmeter -n -t web.jmx -l test.jtl

我这边就是用的第三种方法

jemeter 1S起600个线程 jmeter设置5000线程_内存溢出_02

 

三.小结

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

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