jmeter内存溢出的解决方法
一、在压测过程中jmeter报内存溢出,可能的原因有很多。要注意下面三点:
1、单击压测过程中使用过多的线程,官网建议1000-2000。具体看机器的配置和启动应用的情况。(A single JMeter client running on a 2-3 GHz CPU (recent CPU) can handle 1000-2000 threads depending on the type of test.)
(官网:http://jmeter.apache.org/usermanual/jmeter_distributed_testing_step_by_step.html)
2、监听器里面配置写入到文件,不写入到文件的话所用监听结果存放在内存。还要注意不要使用“察看结果树”监听器。
3、运行压测过程中使用no-gui模式,不要使用界面压测,使用jmeter -n -t这样的命令去运行。
二、解决方法
在我们测试的过程中,线程数过多时常常会导致内存溢出,接下来小编为大家提供内存溢出的解决方法:
1.在jmeter的bin目录下面找到jmeter.properties文件,以记事本形式打开进行编辑
2.在文件中找到以下字段进行修改
Windows环境下面进行修改
将
set HEAP =-Xms256m -Xmx256m
set NEW=-XX:NewSize=128m -XX:MaxNewSize=128m
改成
set HEAP =-Xms256m -Xmx1024m
set NEW=-XX:NewSize=128m -XX:MaxNewSize=512m
友情提示:
heap最多设置为物理内存的一半,默认设置为512M.如果heap超过物理内存的一半,可能运行jmeter会慢,甚至出现内存溢出,原因java比较吃内存,占CPU。
另外注意:JDK32位的电脑Xmx不能超过1500m,最大1378m.否则在启动Jmeter时会出现下面的报错
下面介绍下在Linux系统上面如何进行修改:
Linux环境上面修改jmeter (不用jmeter.sh)
1.方法1:
在jmeter文件开头加上
JAVA_HOME=/apps/jdk1.8.0_121 #如果需要指定java版本可以,可以使用加上
JVM_ARGS="$JVM_ARGS -Xms2G -Xmx10G -XX:MaxPermSize=4096m"
方法2:
替换jmeter文件的最后一句话为:
java $JVM_ARGS -Xms2G -Xmx10G -XX:MaxPermSize=512m -jar `dirname $0`/ApacheJMeter.jar "$@"
如果是 jdk8+,去掉-XX:MaxPermSize=512m参数, 这个参数jdk7以下支持
如果查看JDK的位数
# java -version
java version "1.6.0_26"
Java(TM) SE Runtime Environment (build 1.6.0_26-b03)
Java HotSpot(TM) Server VM (build 20.1-b02, mixed mode)
如果是64位的话,最后一行会显示64-Bit
#java -version
java version "1.6.0_26"
Java(TM) SE Runtime Environment (build 1.6.0_26-b03)
Java HotSpot(TM) 64-Bit Server VM (build 20.1-b02, mixed mode)
三、内存泄露和内存溢出的概念
内存泄露是指你的应用使用资源之后没有及时释放,导致应用内存中持有了不需要的资源,这是一种状态描述;
内存溢出是指你应用的内存已经不能满足正常使用了,堆栈已经达到系统设置的最大值,进而导致崩溃,这事一种结果描述;
通常都是由于内存泄露导致堆栈内存不断增大,从而引发内存溢出。
在利用jmeter测试过程中,如果内存溢出的话,一般会出现这个提示:java.lang.OutOfMemoryError: Java heap space:意思就是堆内存溢出,不够用了。