Jmeter如何进行分布式测试

使用Jmeter进行性能测试时,有些同学问我如果并发数比较大(比如最近项目需要支持1000并发),单台电脑的配置(CPU和内存)可能无法支持,怎么办就需要使用分布式压测

1.分布式原理:

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

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

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

2.执行机配置

1、slave机上需要安装Jmeter,具体如何安装这里不详细介绍了。

2、添加环境变量:JMETER_HOME=D:\B_TOOLS\apache-jmeter-2.13,此处为你Jmeter的路径

3、启动bin目录下的:jmeter-server.bat

4.IP就是slave机器IP,端口默认是1099,端口也可以自定义,这里我自定义为1000,这个后面会讲。

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

3.调度机配置:

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.

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

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

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

2.slave控制台信息

5.选择远程启动-->远程全部启动

6.自定义端口

上面其实已经实现了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. 接口测试:Jmeter插件与分布式

    2024-06-19 07:36:03       29 阅读
  2. jmeter分布式压力测试搭建

    2024-06-19 07:36:03       12 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-06-19 07:36:03       14 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-06-19 07:36:03       16 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-06-19 07:36:03       15 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-06-19 07:36:03       18 阅读

热门阅读

  1. CSS选择器

    2024-06-19 07:36:03       9 阅读
  2. lspci总结

    2024-06-19 07:36:03       6 阅读
  3. 实现ROS中两个里程计数据的转换到同一坐标系下

    2024-06-19 07:36:03       9 阅读
  4. 基础语法总结 —— Python篇

    2024-06-19 07:36:03       5 阅读
  5. Lua迭代器详解(附加红点功能实例)

    2024-06-19 07:36:03       5 阅读
  6. 【C++11】initializer_list详解!

    2024-06-19 07:36:03       6 阅读
  7. QT day4

    QT day4

    2024-06-19 07:36:03      5 阅读
  8. 百度网盘提速攻略:解决限速问题的实用方法

    2024-06-19 07:36:03       8 阅读
  9. vue项目cnpm i 报错

    2024-06-19 07:36:03       5 阅读
  10. 基于springboot的美食推荐商城源码数据库

    2024-06-19 07:36:03       6 阅读
  11. 【HarmonyOS NEXT 】鸿蒙generateBarcode (码图生成)

    2024-06-19 07:36:03       5 阅读
  12. 界面美观的测试报告

    2024-06-19 07:36:03       5 阅读
  13. JWT详解、JWTUtil工具类的构建方法

    2024-06-19 07:36:03       7 阅读
  14. bashrc和profile区别

    2024-06-19 07:36:03       5 阅读