在多机器上远程执行JMeter
Posted lijavasy
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了在多机器上远程执行JMeter相关的知识,希望对你有一定的参考价值。
安装完jmeter之后直接执行%InstallDir%apache-jmeter-3.2inJMeter.bat可以启动UI界面,可以编辑或者执行TestPlan等,默认情况下,用例是在本机执行,而且执行的线程有限,对应的,对服务器的压力也有限。如果我们想要对目标服务器或服务器组增加足够的压力,就需要足够的线程去完成,相对应的,仅仅是一台机器说能执行的线程不足以承担这样的工作量,所以,我们就需要考虑用多台机器同时运行,而且要协同工作,然后对我们的测试环境增压。这种情况,我们就需要改Jmeter的配置来完成:
通常,由于多机器同时运行Jmeter,如果我们用UI的方式去远程执行或者控制的话,当线程比较多时,由于交互比较频繁,数据传递也比较多,这样就容易导致JMeter的UI窗体卡死,甚至直接死掉,最终让我们的执行计划中断。针对这种情况,我们一般用命令行的方式去启动JMeter来执行。
在执行测试之前,我们需要做如下工作:
- 在要执行JMeter的多台机器上都装上JMeter。
- 在上面安装完JMeter的机器中选择一台作为我们的控制器,以用来执行或者停止测试。
- 在控制器上,用记事本打开目录%InstallDir%apache-jmeter-3.2in 下的jmeter.properties 文件。然后找到“# Remote hosts and RMI configuration”,在它的下面有一行如:“remote_hosts=127.0.0.1”,把这行改为如下(对应的IP为其他几台安装JMeter的机器IP),然后保存:
remote_hosts=10.185.76.211,10.185.76.215,10.185.76.216,10.185.76.212,10.185.76.213
4. 然后把编辑好的TestPlan 文件,以及TestPlan需要用到的其他资源文件(如,CSV文件,KeyStore文件等)复制到所有JMeter机器的相同路径下,以便于JMeter执行时能够正确找到。
当然,在执行JMeter测试之前,还得确认测试环境是否正常工作。
等以上准备工作准备好了之后,就可以在控制器上用命令行运行JMeter执行测试了。用管理员权限打开命令行窗口,然后转到文件夹%InstallDir%apache-jmeter-3.2in,命令如下:
jmeter -n -r -t %JMeterTestPlanFile% -e -l %JmeterLogFileName% -o %ReportOutPutFolder%
sample:
jmeter -n -r -t C:TestTestPlanScaleTest.jmx -e -l C:TestDataScaleRunResultLog.jtl -o C:TestData
如果执行的时候没有生成report,可以用下面的命令重新生成report。
jmeter -g %JMeterLogFile% -o %ReportFileWillOutput%
sample:
jmeter -g C:TestDataScaleRunResultLog.jtl -o C:TestData
其他:
Go to your JMeter directory and open your system.properties file.
There, uncomment the following lines, and change the file to match your values:
javax.net.ssl.keyStore=<your_JKS_filename.jks>
javax.net.ssl.keyStorePassword=yourJKSpassword
import cert to keystore:
C:Program FilesJavajre1.8.0_91in>keytool -importkeystore -srckeystore C:certtest.pfx -srcstoretype PKCS12 -srcstorepass password -keystore C:ConfigsApiTest.keystore -storepass password -srcalias 1 -destalias TestStoreName
(完)
以上是关于在多机器上远程执行JMeter的主要内容,如果未能解决你的问题,请参考以下文章
远程的jmeter自动执行完,如何回调通知被调用者“结束”状态