JMeter压测时报“内存不足”故障的9个简单解决方案
Test failed! java.lang.OutOfMemoryError: Java heap space
测试失败了!java.lang.OutOfMemoryError:Java堆空间

在不更改当前硬件设置的情况下获得JMeter测试的最大负载
1.增加Java堆大小
Java堆空间(在错误消息中引用)是JVM从底层操作系统获取的内存,
用于为创建必要对象分配空间。
JMeter的默认配置(请参阅适用于Windows的jmeter.bat或适用于非Windows系统脚本的jmeter)假定堆空间仅为512 MB。
这实际上相当低!
如果您的测试运行超过512Mb的大型对象,
您将收到OOM错误,
并且您的测试将失败。
只需将最大堆大小增加到总可用物理RAM的约80%。
为此,
请在JMeter启动脚本中找到以下行:
HEAP =“ - Xms512m -Xmx512m”
现在相应地更改-Xmx值。
例如:
如果要将最大堆大小设置为4千兆字节,
则需要将行更改为:HEAP =“ - Xms512m -Xmx4096m”
要应用更改,
您需要重新启动JMeter。
2.使用最新软件
如果您的软件已过期,
确保您使用的是以下最新版本:
- Java - 尽可能使用最新的64位版本的Java SE JDK或Server JRE
- JMeter - 最好使用最新版本的JMeter,因为除了任何新功能外,新版本还包含性能改进和错误修复。
- JMeter插件(或其他第三方库) - 原因与Java和JMeter相同
3.在非GUI模式下运行测试
切勿在JMeter GUI上运行负载测试!
仅用于测试记录,开发和调试。
JMeter根本不是为了在GUI模式下产生高负载而设计的,
这意味着它不仅会冻结 - 而且还会消耗大量资源并产生不可靠的负载测试结果。
我建议在命令行模式,
Ant任务或Maven插件中运行负载测试 - 但从不使用GUI。
4.明智地使用监听器
在负载测试期间应禁用监听器。
启用它们会导致额外的开销,
这会占用测试中更重要元素所需的宝贵资源。
您可以在测试完成后使用所需的任何侦听器打开.jtl结果文件并执行其分析。
5.确定您需要存储哪些指标
配置JMeter以确保它只保存您绝对需要的指标。
您可以通过向user.properties文件添加相关行来控制要存储的内容(您可以在JMeter安装的/ bin文件夹中找到它)。

例如:
使用Active Threads Over Time Listener或Response Times vs Threads等监听器,
您需要存储当前活动线程的数量(默认情况下不会这样做)。
要启用此功能,
您需要将“jmeter.save.saveservice.thread_counts = true”行添加到user.properties文件中。
同样,
要控制结果的保存方式,
请搜索jmeter.properties文件的Results File Configuration部分(您也可以在JMeter / bin文件夹中找到它)并检查名称开头的属性的名称和默认值用:“jmeter.save.saveservice”。
找出适当的配置后,
您可以通过指定需要存储哪些指标以及不需要哪些指标来修改user.properties文件。
不要忘记,
在存储请求和响应头时,
断言结果和响应数据会占用大量内存!
因此,
除非绝对必要,
否则尽量不要将这些值存储在JMeter上。
6.选择“正确关联选项”
如果需要从先前的响应中提取某些内容,
请尝试使用正则表达式提取器。
如果由于某种原因不可能(即您需要使用多行复杂正则表达式从HTML获取多个值),
请尝试以下方法之一:
如果页面有一个非常复杂的DOM,但样式的数量相对较少 - 请转到CSS / JQuery Extractor
如果样式数量很高且DOM非常简单 - 请使用XPath Extractor
如果你有足够的时间,
你可以为每个PostProcessor进行实验并获取内存占用量。
这将清楚地显示哪一个更好。
但请记住 - 由于不同的应用程序具有不同的响应,因此必须将此方法应用于每个页面。
7.谨慎使用断言
添加到测试计划中的每个测试元素都将被处理 - 这需要CPU时间和内存。
这也适用于所有断言,
对于比较断言尤其如此- 它消耗大量资源和内存。
只使用你需要的断言,
即使这样,
只需使用绝对需要的数量。
8.检查您的脚本语言
JMeter支持相当多的脚本语言。
但是,
如果您使用基于脚本的采样器来创建实际负载,
则需要使用JSR223采样器和“Groovy”作为语言。
9.“调整”你的JVM
您还可以在JMeter启动脚本中添加或修改以下JVM参数:
在JMeter启动脚本中找到NEW =“ - XX:NewSize = 128m -XX:MaxNewSize = 128m”行。取消注释并增加值以匹配您为HEAP设置的值
-server - 通过运行时参数优化将JVM切换到“服务器”模式。在这种模式下,JMeter启动速度更慢,但总体吞吐量会更高
-d64 - 如果您有64位操作系统,请使用此参数明确告诉JVM以64位模式运行
-XX:+ UseConcMarkSweepGC - 这会强制使用CMS垃圾收集器。它将降低整体吞吐量,但会导致更短的CPU密集型垃圾收集。
-XX:+ DisableExplicitGC - 这可以防止应用程序强制进行昂贵的垃圾收集,并有助于避免意外暂停。如果您认为JMeter的吞吐量可能更好并且它没有充分利用JVM,操作系统和机器资源,请尝试使用JConsole或VisualVM来监视JMeter进程并检查堆大小使用情况,GC间隔,系统在垃圾中花费的时间收集等。理想情况下,GC应该看起来像健康人的“脉搏”。垃圾收集器应该经常射击以防止OOM - 但不是太多,以至于强烈感受到它的影响。
JMeter压测时报“内存不足”故障的9个简单解决方案的更多相关文章
- dubbo的jmeter压测时jar包的热加载/动态加载
在做dubbo的jmeter压测时,需要把jar包放入jmeter的lib/ext目录下,但是jmeter启动的时候会自动加载这个目录lib目录及lib/ext目录,这样启动后放入这些目录下的jar包 ...
- jmeter --- 压测时,如何让串联压测多个接口
1.新建测试计划,在测试计划里勾选“独立运行每个线程组” 2.分别在每个线程组,添加聚合报告,以得到每个线程组的压测结果 3.设置不同接口压测的vu等,并为每个线程组,设置合理的启动延迟时间
- 在linux上用jmeter压测时出现很多异常java.net.NoRouteToHostException: Cannot assign requested address.
今天压力测试时, 刚开始出现了很多异常, 都是 java.net.NoRouteToHostException: Cannot assign requested address. 经网上查资料, 是由 ...
- jmeter压测前清理内存
jmeter 压测时设置了内存为sed -i 's/HEAP="-Xms512m -Xmx512m"/HEAP="-Xms36096m -Xmx360096m" ...
- Jmeter压测报错:Non HTTP response code: java.net.ConnectExceptionexception的解决办法
前一段时间进行jmeter压测时,一直报错,查看了下日志才发现报了一堆Non HTTP response code: java.net.ConnectExceptionexception,直接jmet ...
- Jmeter报内存溢出解决方案
描述:wimdows环境,做上传图片接口测试,涉及图片合成和上传,图片采用base64编码.每1s启动200线程的时候,Jmeter报内存溢出错误. 解决方案: 1.修改jmeter.bat: set ...
- jmeter压测学习12-设置持续压测时间(调度器的使用)
前言 使用jmeter 做压测的时候,希望对一个接口持续压测 10 分钟或者半小时,可以使用调度器设置持续压测时间. 设置样本总数 压测方式有2种,一种是设置线程组和循环次数,这样可以设置一个样本总数 ...
- wrk,ab,locust,Jmeter 压测结果比较
背景: 项目需要对一批接口进行压测,要求是接口的QPS(Quest Per Second每秒请求数)达到6万以上由于楼主一直使用的压力测试工具是jmeter,但是jmeter单台电脑无法达到6万的QP ...
- windows下Jmeter压测端口占用问题(亲测有效)
windows下Jmeter压测端口占用问题 1 报错信息描述 压测的初期,在设置了 150qps/s 的并发数下压测几分钟后 Jmeter 就出现了如下报错. JAVA.NET.BINDEXCEPT ...
随机推荐
- 设计模式php+java版本(1) 基础篇 七大原则
2019年9月6日11:15:46 关于设计模式,其实就是编程思想的一个体现,有比较完善的编程思想写出的项目代码和没有编程思想的写出的差距巨大,代码的可读性,可维护性,可扩展性天差地别,有些刚接触的编 ...
- 使用Android手机进行开发的尝试
使用Android手机查看和修改Excel文件.PowerPoint文件并连接幻灯机进行演示等办公方式想必大家已经有所了解.今天介绍一下怎样使用Android进行软件开发. Termux 使用Andr ...
- 【ARM-Linux开发】ARM嵌入式设备Linux系统启动步骤和方式
1). 简介 本文简单介绍ARM嵌入式设备基于嵌入式Linux操作系统时候的启动步骤和启动方式, 区别与X86平台,ARM平台下并没有一个标准的启动步骤,不同ARM SoC都会使用各自定义的boot ...
- 执行sudo supervisorctl reload报错ImportError: No module named supervisor.supervisord
由于yum install supervisor 会默认使用python2.6环境,首先要安装好python2.6的环境,然后修改以下文件首行为2.6即可 [root@VM_0_15_centos ~ ...
- ChecklistForTest
相关字段内容较长时,页面显示是否正确(包括各主页面.明细页面.打印预览页面) 数据量较多时,页面显示是否正确(包括各主页面.明细页面.打印预览页面) 各字段为空校验(都为空,部分为空,都不为空)是否正 ...
- C++ 智能指针 boost::scoped_ptr分析
1.scoped_ptr的实现原理及特性 特性:scoped_ptr和auto_ptr类似,但最大的区别就是不能转让管理权限,也就是说scoped_ptr禁止用户进行拷贝和赋值 实现原理:如何才能禁止 ...
- SpringBoot应用部署到Docker上(docker-ce版本)
配置TCP远程连接(docker-maven-plugin插件连接的地址) # 加上红色标识的部分[root@localhost admin]# vim /lib/systemd/system/doc ...
- xe.10.2的下载路径
为了这个玩意,我折腾了一天,为了以后自己还用到 官网地址: http://altd.embarcadero.com/download/radstudio/10.2/delphicbuilder10_2 ...
- Partition5:Partiton Scheme是否指定Next Used?
在SQL Server中,为Partition Scheme多次指定Next Used,不会出错,最后一次指定的FileGroup是Partition Scheme的Next Used,建议,在执行P ...
- Oracle学习笔记(四)
Oracle中的体系结构: oracle体系结构中的进程: 共享池相关的优化: drop table t purge; create table t as select * from dba_obje ...