安装完jmeter之后直接执行%InstallDir%\apache-jmeter-3.2\bin\JMeter.bat可以启动UI界面,可以编辑或者执行TestPlan等,默认情况下,用例是在本机执行,而且执行的线程有限,对应的,对服务器的压力也有限。如果我们想要对目标服务器或服务器组增加足够的压力,就需要足够的线程去完成,相对应的,仅仅是一台机器说能执行的线程不足以承担这样的工作量,所以,我们就需要考虑用多台机器同时运行,而且要协同工作,然后对我们的测试环境增压。这种情况,我们就需要改Jmeter的配置来完成:

通常,由于多机器同时运行Jmeter,如果我们用UI的方式去远程执行或者控制的话,当线程比较多时,由于交互比较频繁,数据传递也比较多,这样就容易导致JMeter的UI窗体卡死,甚至直接死掉,最终让我们的执行计划中断。针对这种情况,我们一般用命令行的方式去启动JMeter来执行。

在执行测试之前,我们需要做如下工作:

  1. 在要执行JMeter的多台机器上都装上JMeter。
  2. 在上面安装完JMeter的机器中选择一台作为我们的控制器,以用来执行或者停止测试。
  3. 在控制器上,用记事本打开目录%InstallDir%\apache-jmeter-3.2\bin\ 下的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执行时能够正确找到。

5. 在除控制器之外的其他JMeter的主机上启动JMeter,直接到%InstallDir%\apache-jmeter-3.2\bin\下从命令行执行".\jmeter.bat -s" 来启动JMeter server.

当然,在执行JMeter测试之前,还得确认测试环境是否正常工作。

等以上准备工作准备好了之后,就可以在控制器上用命令行运行JMeter执行测试了。用管理员权限打开命令行窗口,然后转到文件夹%InstallDir%\apache-jmeter-3.2\bin,命令如下:

jmeter -n -r -t %JMeterTestPlanFile% -e -l %JmeterLogFileName% -o %ReportOutPutFolder%

sample:

jmeter -n -r -t C:\TestTestPlan\ScaleTest.jmx -e -l C:\TestData\ScaleRunResultLog.jtl -o C:\TestData\

如果执行的时候没有生成report,可以用下面的命令重新生成report。

jmeter -g %JMeterLogFile% -o %ReportFileWillOutput%

sample:

jmeter -g C:\TestData\ScaleRunResultLog.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 Files\Java\jre1.8.0_91\bin>keytool -importkeystore -srckeystore C:\certtest.pfx -srcstoretype PKCS12 -srcstorepass password -keystore C:\Configs\ApiTest.keystore -storepass password -srcalias 1 -destalias TestStoreName

(完)

在多机器上远程执行JMeter的更多相关文章

  1. ssh 远程执行命令 nohup 无效问题

    昨夜1:00多准备睡觉了,突然一哥们咨询了我一个问题. 他A机器上远程执行B机器(ssh user@ip "command")上的脚本,B上的服务并没有起来. 看了下截图,脚本确实 ...

  2. 开发机器上利用vs2013调试远程IIS上的c#程序

    当远程IIS上的C#程序出现问题,怎么排错,一般我们通过看日志排查错误的方法,这种方法在程序异常日志都打印出来的情况下是可以解决的,但如果程序日志不详细,或者从日志看不出有用的内容的时候怎么排错? 本 ...

  3. 两台linux服务器之间免密scp,在A机器上向B远程拷贝文件

    两台linux服务器之间免密scp,在A机器上向B远程拷贝文件 操作步骤:1.在A机器上,执行ssh-keygen -t rsa,一路按Enter,不需要输入任何内容.(如有提示是否覆盖,可输入y后按 ...

  4. SSH 无密码远程执行脚本

    ssh无密码登录及远程执行脚本要使用公钥与私钥.linux下可以用用ssh-keygen生成公钥/私钥对,下面我以CentOS7为例. 测试环境:机器A(10.0.224.80):机器B(192.16 ...

  5. 解决SSH远程执行命令找不到环境变量的问题

    通过SSH执行远程主机的命令或脚本时,经常会出现找不到自定义环境变量的问题.但是,如果通过SSH登录远程主机,然后再执行相同的命令或脚本,那么此时执行又是成功的.两种相似的方法,得到的结果却截然不同, ...

  6. Linux远程执行shell命令

    Linux远程执行shell命令   在Linux系统中,我们经常想在A机器上,执行B机器上的SHELL命令. 下面这种方案,是一种流行可靠的方案. 1.SSH无密码登录 # 本地服务器执行(A机器) ...

  7. Jenkins 为Jenkins添加Windows Slave远程执行python项目脚本

    为Jenkins添加Windows Slave远程执行python项目脚本   by:授客 QQ:1033553122 测试环境 JAVA JDK 1.7.0_13 (jdk-7u13-windows ...

  8. sheel远程执行

    https://www.cnblogs.com/softidea/p/6855045.html shell远程执行: 经常需要远程到其他节点上执行一些shell命令,如果分别ssh到每台主机上再去执行 ...

  9. SSH远程执行命令环境变量问题

    SSH命令格式 usage: ssh [-1246AaCfgKkMNnqsTtVvXxYy] [-b bind_address] [-c cipher_spec] [-D [bind_address: ...

随机推荐

  1. Spark学习笔记11面向对象编程

    面向对象编程   11.1 object类 11.1.1定义一个简单的类   11.1.2 field的getter与setter 定义类包含,定义类的field及方法.其格式如下 class Cla ...

  2. mysql实现开窗函数

    mysql实现开窗函数 http://blog.itpub.net/29989552/viewspace-2123077/ 学习过oracle的应该知道,oracle中的分析函数功能十分强大,包括ms ...

  3. 【Bad Practice】12306 query

  4. 20175211 2018-2019-2 《Java程序设计》第五周学习总结

    目录 教材学习内容总结 第六章 接口与实现 教材学习中的问题和解决过程 代码调试中的问题和解决过程 代码托管 上周考试错题总结 学习进度条 参考资料 教材学习内容总结 第六章 接口与实现 6.1 接口 ...

  5. git提交到一半关闭时

    一:出现问题 最近写东西,在提交代码时,突然出现一大推文件... 忘记加.gitignore文件了,导致所有的安装依赖也都上传了.所以,点击了关闭按钮,当下一次提交时,出现了错误. Another g ...

  6. Centos7安装jexus,部署asp.net core,asp.net mvc

    什么是Jexus 官网解释:https://www.jexus.org/ Jexus是一款Linux平台上的高性能WEB服务器和负载均衡网关,Jexus Web Service,简称JWS,以支持AS ...

  7. linux 下常用的50条命令

    1.find 查换文件.目录和权限 find . -name aaa.txt 在当前目录及子目录查找文件名为aaa.txt文件 find . -name "*.txt" -o -n ...

  8. 工厂方法 Factory Method

    背景:有一个应用框架,它可以向用户显示多个文档.在这个框架中,两个主要的抽象是类Application和Document.这两个类都是抽象的.客户必须通过它们的子类来做与举替应用相关的实现. 分析:因 ...

  9. Ubuntu MariaDB PhpMyAdmin

    root@www:~# apt-get -y install phpmyadmin php-mbstring php-gettext # select which one you using (thi ...

  10. 单链表反转java代码

    据说单链表反转问题面试中经常问,而链表这个东西相对于数组的确稍微难想象,因此今天纪录一下单链表反转的代码. 1,先定义一个节点类. public class Node { int index; Nod ...