在使用Jmeter做性能测试过程中,可能会应为默认设置的堆内存值较小出现堆内存溢出问题,此时解决的方式有两种,分布式测试和调大堆内存。下面介绍官方推荐调整堆内存方法。
了解Jmeter最便捷的方式就是看官方文档,它提供了全方位的Jmeter介绍。如果没有阅读官方文档的习惯可能会走一些弯路,因此推荐一条好走的路。
官方文档地址:https://jmeter.apache.org/usermanual/get-started.html
1.Jmeter使用手册展示
2.带你从手册查找JVM正确的配置方式
点击Getting Started打开手册
在1.4章节Running Jmeter中官方介绍了配置环境变量的方式,就是在Jmeter的bin目录下新建一个setenv.bat文件,官方还给出了在文件中配置JVM参数的例子。
为什么网上提供的jmeter.bat文件修改jvm参数不生效那?官网也给出了答案。
原因是优先级顺序,setenv.bat文件配置会覆盖jmeter.bat配置内容。
1.linux和windows配置jvm区别
linux环境配置Jmeter的JVM参数和window环境配置原理一样,只有两点区别
Linux环境创建的setenv脚本文件后缀不是bat,是sh。(setenv.sh)
setenv.sh脚本文件语法格式稍有区别。window解析bat文件使用set语法设置变量,linux解析shell语言使用export设置变量。
2.官方提供的linux环境配置jvm方法
继续阅读官方手册1.4 Running JMeter章节,官方文档指出在bin目录中创建setenv.sh文件,并在该文件中配置jvm,所配置的内容将在Jmeter启动时候被jmeter脚本文件读取。
1.windows配置jvm两种方式
在jmeter.bat文件中修改jvm参数,如下图。
在bin目录创建setenv.bat文件修改jvm参数,它的优先级高于jmeter.bat会覆盖该文件内容。
2.Linux环境配置jvm参数两种方式
在jmeter没有后缀的文件中配置jvm参数
jmeter配置jvm脚本
在bin目录下新建setenv.sh文件配置jvm参数,它的优先级高于jmeter脚本,覆盖该脚本参数。
1.在jmeter.bat文件配置jvm参数
2.启动Jmeter验证jvm配置
使用Java VisualVM工具查看Jmeter设置的堆内存结果。
1.setenv.bat文件配置jvm
在bin目录下新建setenv.bat文件,在文件中配置JVM参数
rem This is the content of bin\setenv.bat,
rem it will be called by bin\jmeter.bat
set JVM_ARGS=-Xms256m -Xmx256m -XX:MaxMetaspaceSize=256m
2.启动Jmeter验证jvm配置
使用Java VisualVM工具查看Jmeter设置的堆内存结果。
1.创建setenv.sh文件
在jmeter的bin目录下新建setenv.sh配置文件,在文件中配置jvm参数
export JVM_ARGS="-Xms256m -Xmx256m -XX:MaxMetaspaceSize=256m"
2.启动jmeter脚本查看jvm参数
命令方式启动jmeter脚本
// jmeter命令调用的就是bin目录下的jmeter脚本文件,因此他会在启动时读取setenv.sh文件中jvm参数。
jmeter -n -t ./JmeterScript/LiveStreaming.jmx
查看Jmeter的jvm参数和设置值一致
最后感谢每一个认真阅读我文章的人,礼尚往来总是要有的,虽然不是什么很值钱的东西,如果你用得到的话可以直接拿走:
这些资料,对于【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴上万个测试工程师们走过最艰难的路程,希望也能帮助到你!