Jmeter分布式测试

在使用Jmeter进行性能测试时,如果并发数比较大(比如最近项目需要支持1000并发),单台电脑的配置(CPU和内存)可能无法支持,这时可以使用Jmeter提供的分布式测试的功能。

一、Jmeter分布式执行原理:

  1、Jmeter分布式测试时,选择其中一台作为调度机(master),其它机器做为执行机(slave)。

  2、执行时,master会把脚本发送到每台slave上,slave 拿到脚本后就开始执行,slave执行时不需要启动GUI,只需要打开jmeter-server.bat,我理解它应该是通过命令行模式执行的。

  3、执行完成后,slave会把结果回传给master,master会收集所有slave的信息并汇总。

 

二、执行机(slave)配置:

  1、slave机上需要安装JDK和Jmeter,slave中的jmeter和jdk版本最好和master的一致,具体如何安装这里不详细介绍了,和master安装一致即可,详情可见我的这篇博文http://blog.csdn.net/u013258415/article/details/76412910。

PS:

(1)slave建议Jmeter版本从master中直接copy,防止因为版本和插件差异出现问题

(2)JDK大版本一致即可,不分32bit和64bit,如jdk-8u141-windows-x64_8.0.1410.15.exe和jdk-8u77-windows-i586.exe即是版本都是1.8

  2、添加环境变量:JMETER_HOME=D:\B_TOOLS\apache-jmeter-2.13,此处为你Jmeter的路径(说明:此处是保证JMeter的正常运行,不影响多节点的运行的,具体后面可以看我的配置)

     3、在slave机的Jmeter的bin目录下,找到jmeter.properties文件,修改如下两个配置项,端口默认是1099,比如我这里修改为1099,,找到server_port和erver.rmi.localport去除前面的#即可
           server_port=1099
           server.rmi.localport=1099

        (端口也可以自定义,可以选择配置其他端口,但是建议一定要选择配置一个,不然容易出现问题,不配置端口会被随机设置,比如出现弹出框说error initialising server x.x.x.x   no such object in table)

  4、启动bin目录下的:jmeter-server.bat,启动成功如下图:

  

  5、上图上标红的IP和端口会在master里配置时用到。IP就是slave机器IP,端口默认是1099,端口也可以自定义,这里我自定义为1000,这个后面具体会讲。 

  6、多台slave的话,重复1~4步骤就好。  

 

三、调度机(master)配置:

  1、脚本:简单的一个访问百度的脚本: 

  

  2、找到Jmeter的bin目录下jmeter.properties文件,修改如下配置,IP和Port是slave机的IP以及自定义的端口(这里端口我自定义为100,后面会讲如何自定义):

        remote_hosts=10.13.223.202:1000,10.13.225.12:1000

    多台slave之前用","隔开,我这配置了2台,可以看到标红的这个就是上面截图slave的IP和Port.

PS:如果jmeter.properties修改过了,需要关闭jmeter.bat,再重新启动jmeter.bat

  3、打开Jmeter,选择运行,有运程启动、运程全部启动两个选项:

  

  4、选择远程启动-->10.13.225.12:1000

    a) master结果,这里我只启动了10.13.225.12:1000这一台slave,所以只有一个结果(线程数和循环次数都是1):

  

    b) slave控制台信息:

   

  5、选择远程启动-->远程全部启动:

    a) master结果,全部启动,我配置了2台slave,所以有两次执行结果:

  

  

四、自定义端口:

  上面其实已经实现了Jmeter的分布式测试,这部分主要介绍下如何自定义slave端口:

  1、slave:在slave机的Jmeter的bin目录下,找到jmeter.properties文件,修改如下两个配置项,比如我这里修改为1888:

      server_port=1888

      server.rmi.localport=1888

  2、启动slave机上的jmeter-server.bat如下图,端口已经修改为:1888

  

  3、master:修改master机器的jmeter.properties文件:

      remote_hosts=10.13.223.202:1000,10.13.225.12:1888

  4、重启jmeter.bat,如下图,端口已经变了:

  

 

五、其它说明:

  1、调度机(master)和执行机(slave)最好分开,由于master需要发送信息给slave并且会接收slave回传回来的测试数据,所以mater自身会有消耗,所以建议单独用一台机器作为mater。

  2、参数文件:如果使用csv进行参数化,那么需要把参数文件在每台slave上拷一份且路径需要设置成一样的。

  3、每台机器上安装的Jmeter版本和插件最好都一致(建议直接copy),否则会出一些意外的问题。

      

PS:如果jmeter 要做mysql jdbc分布式的话,要在salve(执行机)的lib目录中放入jar包,如mysql-connector-java-6.0.6-bin.jar

对于其他说明中的第二点:

参数文件路径必须为绝对路径,否则脚本执行时无法找到参数配置文件,因为调度机(Controller)分发JMX脚本,但不分发脚本中对应的参数文件。

slave执行机依据参数化配置,将对应的参数化文件拷贝到对应的配置路径。执行机(Slave)对应路径下必须存在正确的参数文件。


转载于:http://www.cnblogs.com/puresoul/p/4844539.html

参考:https://zhuanlan.zhihu.com/p/28031727?utm_source=qq&utm_medium=social

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
JMeter分布式测试是指将测试负载分散到多台计算机上进行测试,以模拟真实的生产环境。它可以提高测试效率和准确性,因为分布式测试可以模拟真实环境中的多个用户同时访问网站或应用程序的情况。同时,分布式测试可以减轻单台计算机的负担,避免测试过程中的资源竞争问题。 JMeter分布式测试的实现需要以下步骤: 1. 配置JMeter主控机和从机之间的通信 2. 配置JMeter从机的IP地址和端口 3. 在JMeter主控机上创建测试计划,并将它们保存到文件中 4. 在JMeter从机上启动JMeter服务器,并加载测试计划文件 5. 在JMeter主控机上启动分布式测试,并指定从机的IP地址和端口 6. 监控测试过程,并收集测试结果 JMeter分布式测试的优点包括: 1. 提高测试效率和准确性 2. 模拟真实环境中的多用户访问 3. 避免资源竞争问题 4. 可以扩展测试环境,以支持更大规模的测试 5. 可以在不同的操作系统和硬件环境下进行测试 JMeter分布式测试的缺点包括: 1. 需要额外的配置和设置 2. 可能会增加测试的复杂性 3. 依赖于网络的稳定性和速度 4. 需要更多的计算机和资源 总之,JMeter分布式测试是一种非常有用的测试方法,可以提高测试效率和准确性,同时也可以模拟真实环境中的多用户访问。但是,它需要额外的配置和设置,并且依赖于网络的稳定性和速度。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值