安装完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. pc端字体大小自适应几种方法

    $(window).resize(function ()// 绑定到窗口的这个事件中 {  var whdef = 100/1920;// 表示1920的设计图,使用100PX的默认值  var wH ...

  2. [LintCode] 77. Longest common subsequences_ Medium tag: Dynamic Programming

    Given two strings, find the longest common subsequence (LCS). Example Example 1: Input: "ABCD&q ...

  3. Ubuntu设置su和sudo为不需要密码 (摘录自别处)

    版权声明:本文为博主原创文章,未经博主允许不得转载. https://blog.csdn.net/langb2014/article/details/54646675 针对非服务器用户,只是用普通的U ...

  4. bootstrap4 Reboot details summary 美化(点选禁止选中文本,单行隐藏角标,多行后移)

    bootstrap4 Reboot details summary 优化这块,主要是为了去掉details summary的角标~ 所以优化写了一下. 原始HTML <details> & ...

  5. 深入了解webpack前,可以了解的小知识点。

    阅读前:文章大概是写,简单用过webpack,想继续深入了解webpack前需要了解的知识.但文章内容跟webpack使用关系并不大. 文章概要: Object.defineProperty call ...

  6. 命令行下执行python找不包的解决方法

    首先我们来了解一下,为什么会出现这样的问题,以及python搜索包的机制是怎么样的 1.为什么会出现这样的问题? 包是向下搜索机制. 2.为什么ide中执行没有报找不到包的问题? python搜索机制 ...

  7. CDI services--Decorators(装饰器)

    1.Decorators装饰器综述 拦截器是一种强大的方法在应用程序捕捉运行方法和解耦.拦截器可以拦截任何java类型的调用. 这使得拦截器适合解决事务管理,安全性,以及日记记录. 本质上说,拦截器并 ...

  8. HDFS之HA

    HDFS高可用环境HA的架构 HDFS组件由一个对外提供服务的namenode(存储元数据)和N个datanode组成:Zookeeper有三个作用:1.为了统一配置文件 config 2.多个节点的 ...

  9. django--orm对象关系映射之常用的增删改查

    1.查询表里所有数据 book=models.Book.objects.all() 2.条件查询 book = models.Book.objects.filter(id=1).first() # 查 ...

  10. CentOS7中OpenVPN的配置

    最近需要在openstack中集成openvpn功能,故熟悉了一下openvpn的搭建流程,记录下来,供参考 版本:openvpn-2.3.4.tar.gz 下载地址:http://pan.baidu ...