1、场景
在做性能测试时,单台机器进行压测可能达不到预期结果。主要原因是单台机器压到一定程度会出现瓶颈。也有可能单机网卡跟不上造成结果偏差较大。
例如4C8G的window server机器,使用UI方式,最高压测在1800并发(RT 20ms以内)左右。如果对于XML文件进行解析,更容易吃CPU,并发数会更低。
当单台机器不能支持更大的并发时需要考虑分布式压力测试。
2、原理
原理图如下:
- Jmeter分布式测试时,选择其中一台作为调度机(master),其它机器做为执行机(slave)
- master通过GUI界面启动slave机器,将jmeter压测发送给每台启动的slave
- slave启动jmeter-server,获得脚本后开始执行
- slave执行完成后将结果传回给master,master收集整合显示
在这我为大家准备了一份软件测试视频教程(含面试、接口、自动化、性能测试等),就在下方,需要的可以直接去观看,也可以直接【点击文末小卡片免费领取资料文档】
软件测试视频教程观看处:
软件测试工程师大忌!盲目自学软件测试真的会毁终生,能救一个是一个......
3、注意事项
1.关闭防火墙和杀毒软件,开放端口
$ service firewalld stop
$ service iptables stop
2.所有机器最好在同一个子网上
可以使用ping命令进行检查
3.所有机器中最好使用相同版本的jdk和jmeter
4.禁用SSL
如果在启动jmeter-server.bat 时出现如下错误,则SSL没有禁用
禁用方法,jmeter.properties文件下查找server.rmi.ssl.disable,取消注释,并将其值修改为true:server.rmi.ssl.disable=true
4、slave配置
在slave机器中,启动bin目录下的 jmeter-server.bat,如下图:
启动后的ip和port为:192.168.10.131:50043
当然启动时端口也是可以自定义的。
在slave机器的 Jmeter的bin目录下,修改jmeter.properties文件下的server_port和server.rmi.localport两个配置项。比如修改为1000:
server_port=4444
server.rmi.localport=4444
启动后的ip和port为:192.168.10.131:4444
5、master配置
在master机器的 Jmeter的bin目录下,修改jmeter.properties文件下的remote_hosts项,添加IP和port,多台slave的情况下,使用逗号(,)进行分割。
完成配置后启动master机器上的 jmeter。
在Run>>Remote Start下可以查看配置的remote_hosts项。
注意:如果jmeter已经启动,修改jmeter.properties文件后需要重启jmeter配置项才可以生效。
6、脚本执行
新建一个线程组,线程组下添加一个debug sampler调试采样器和一个树结构监听器
将debug sampler重新命名为:${__machineIP()} ,该函数的意思是获取执行机器的ip
通过菜单栏的开始按钮运行脚本
通过 Run>>Remote Start>>192.168.10.131:4444运行脚本
如果要同时在所有的 slave 机器上运行,则通过 Run>>Remote Start All 执行脚本
注意:在分布式执行中,master向slave发送测试计划时不会将外部文件一起发送。所以在测试中如果使用csv等外部文件进行参数化,则需要把参数文件在每台slave上拷贝一份,最好都放置在bin目录下,因为Jmeter会直接从bin目录下查找。
PS:这里分享一套软件测试的自学教程合集。对于在测试行业发展的小伙伴们来说应该会很有帮助。除了基础入门的资源,博主也收集不少进阶自动化的资源,从理论到实战,知行合一才能真正的掌握。全套内容已经打包到网盘,内容总量接近500个G。【点击文末小卡片免费领取】
这些资料,对于做【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴我走过了最艰难的路程,希望也能帮助到你!凡事要趁早,特别是技术行业,一定要提升技术功底。文章来源:https://www.toymoban.com/news/detail-752987.html
文章来源地址https://www.toymoban.com/news/detail-752987.html
到了这里,关于Jmeter分布式压力测试详解的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!