Jmeter性能测试分布式技术

本文介绍JMeter如何进行分布式性能测试,包括配置Master和Slave机器、连接机器、执行测试等内容。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

目录

Jmeter性能测试分布式技术

一、什么是分布式测试

二、执行原理

三、分布式配置

1.Master机器配置

2.Slave机器配置

四、连接机器

五、执行测试


Jmeter性能测试分布式技术

一、什么是分布式测试

  分布式测试是指通过局域网和Internet,把分布于不同地点、独立完成特定功能的测试计算机连接起来,以达到测试资源共享、分散操作、集中管理、协同工作、负载均衡、测试过程监控等目的的计算机网络测试

二、执行原理

  对分布式测试而言,测试过程是一种对流程控制要求很高的活动,因此系统需要适时地获取全局状态以正确地指导流程;其次,在测试过程中,系统要能够方便地监视和操纵测试过程。因此,分布式测试系统适合采用集中式的分布式策略,即由一台中心计算机控制若干台受控计算机的执行,整个测试过程和资源管理由中心来完成,它掌握整个分布式测试环境的状态,从而发出控制命令

  1. 选择其中一台作为Master机(调度机),其他机器作为Slave机(执行机)
  2. 执行时,Master机会把脚本发送到每台Slave机上,Slave机拿到脚本后就开始执行,不需要启动GUI
  3. 执行完成后,Slave机会把结果回传给Master机,Master机会收集所有Slave机的信息,并汇总

三、分布式配置

  前提条件:

  • Slave机器的jdk版本需要跟Master机器的jdk版本保持一致
  • Slave机器的Jmeter版本以及插件需要跟Master机器保持一致,操作方法是直接将Master的Jmeter安装目录打包后解压到Slave机器上
  • Slave机器的网络需要跟Master机器的网络保持在同一个局域网,可以ping通(--在我的实际使用中,Slave机器和Master机器需要在同一网段,在不同网段的Slave机器无法执行脚本)

1.Master机器配置

  在Jmeter的%JMETER_HOME%\bin目录下,使用文本编辑工具打开jmeter.properties配置文件,配置以下参数

  • remote_hosts=Slave机器IP:端口  多台Slave机器则用英文逗号隔开
  • server.rmi.ssl.disable=true
  • mode=Standard  开启标准模式(可以看到日志记录)

  配置完成后重启Jmeter

2.Slave机器配置

  在Jmeter的%JMETER_HOME%\bin目录下,使用文本编辑工具打开jmeter.properties配置文件,配置以下参数

  • server_port=1234
  • server.rmi.port=1234
  • server.rmi.ssl.disable=true  去掉认证

  如果是linux机器上,则要给bin目录赋予执行的权限:chmod +x -R bin/,防火墙有些操作系统也需要提前关闭:systemctl stop firewalld.service

四、连接机器

  配置完成,检查防火墙也关闭后,在Slave机器的Jmeter的%JMETER_HOME%\bin目录下,输入cmd进入命令行模式

  在命令行下开启Jmeter远程服务:jmeter-server.bat -Djava.rmi.server.hostname=本机IP,如果是linux机器,命令为:sh jmeter-server.sh -Djava.rmi.server.hostname=本机IP

  我们在Master机器上,打开cmd终端命令行,使用“telnet IP 端口”的命令验证是否接通

 

   如上面显示则表示已经接通,可以开始进行分布式性能测试了

五、执行测试

  分布式测试的场景,Master机器上只发送指令并收集测试结果,多台Slave机器执行Master机器发送的指令,并且Master机器上设定的并发用户数在每台Slave机器上执行的并发用户数保持一致,总的并发用户数=并发用户数*n(Slave机器个数)

  在Master机器上重新打开Jmeter的GUI界面,点击:运行—远程启动—Slave机器

 

  因为资源有限,只使用了一台Slave机器

 

  我们可以看到Slave机器上打印了相应的日志,则说明分布式场景配置成功:

六、所遇问题及解决方案

1.添加完Slave机器后,Master机器远程启动Slave机器时无法执行脚本

解决方法:Slave机器和Master机器不在同一网段导致,

                  当Slave机器和Master机器在同一网段时无此问题。

2.Master机器远程启动测试,Slave机器显示连接后立即结束,看似执行实则响应数据为空

解决方法:jmeter测试数据(.csv文件)未放到Slave机器上或测试数据(.csv文件)的存放路径与jmeter脚本中.csv读取路径不一致导致该问题,

                 将测试数据文件拷贝到Slave机器上,并保证存放路径与脚本中数据文件读取路径一致可解决。

 

作者:白白BYM

出处:https://www.cnblogs.com/xiaogongjin/p/12006356.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值