赞
踩
在Linux上压测报错JMeter内存溢出:java.lang.OutOfMemoryError: Java heap space 解决方法【纯干货,无废话】
使用jmeter进行压测过程中,并发数过大时会导致内存溢出,jmeter卡死,内存泄露是指使用资源后没有及时释放, 导致内存中持有了不需要的资源; 内存溢出是指应用的内存已经不能满足正常使用了,堆栈已经达到系统设置的最大值,进而导致Crash;用JMeter压测,有时候当模拟并发请求较大或者脚本运行时间较长时,JMeter会停止,报OOM(内存溢出)错误, 并发线程高,内存溢出问题
Uncaught Exception java.lang.OutOfMemoryError: Java heap space in thread Thread[StandardJMeterEngine,5,main]. See log file for details.
原因是:JMeter是一个纯Java开发的工具,内存由java虚拟机JVM管理,当内存回收不及时,堆内存不足时,就会报内存溢错误。
# 概念补充:
内存泄露:应用使用资源之后没有及时释放,导致应用内存中持有了不需要的资源。
内存溢出:应用的内存已经不能满足正常使用了,堆栈已经达到系统设置的最大值,进而导致崩溃。
通常都是由于内存泄露导致堆栈内存不断增大,从而引发内存溢出。
对JMeter而言也是如此,JMeter测试过程中,如果内存溢出的话,一般会出现上图中的提示:java.lang.OutOfMemoryError: Java heap space:意思就是堆内存溢出,不够用了
1.Linux下jmeter jvm参数修改,打开jmeter安装目录/bin/jmeter (非jmeter.sh 文件)
2.解决方法如下:
解决:
编辑jmeter
搜索 : "${HEAP:="-Xms1g -Xmx1g -XX:MaxMetaspaceSize=256m"}"
改变初始堆内存和最大堆内存
根据自己的机器内存修改,我改的是:
3.发布后正常启动。
这个值不是越大越好,要根据压测使用的机器而定,一般而言,堆内存的最大值不要超过物理内存的一半,否则容易导致jmeter运行变慢、
卡顿甚至内存溢出(因为java本身的垃圾回收机制是动态分配内存,调整的时候其本身会占用很多内存),NEW分配的内存,不宜太大。
2、修改完成后保存,重启JMeter,即可生效。
1、这种修改堆大小的方法只适用一部分情况,并不是万能的,当需要模拟的线程数较大时,就需要根据具体情况采用分布式压测的方式了。
2、命令行运行JMeter时,一定要禁用“查看结果树”、“聚合报告”等监听器,因为真的真的真的很消耗内存。
from chatGp answer:
jmeter压测结束出现java_pid58971.hprof
java_pid*.hprof文件通常是Java虚拟机的堆转储文件,用于分析Java应用程序的内存使用情况。这个文件的出现可能是因为在进行JMeter压力测试期间,Java虚拟机内存达到了某个阈值,导致自动转储了堆信息。这通常是JVM进行自我保护的一种机制,以避免出现内存泄漏或内存溢出等问题。
在JMeter压测结束后出现java_pid*.hprof文件并不会影响测试结果。您可以选择保留该文件以便后续进行内存分析,或者删除该文件以释放磁盘空间。如果您不需要进行内存分析,则可以放心地删除该文件。
如果您想要更深入地了解java_pid*.hprof文件,建议您查阅Java虚拟机相关的文档和资料。
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。