当前位置: 首页 > news >正文

Jmeter分布式压力测试

目录

1、场景

2、原理

3、注意事项

4、slave配置

5、master配置

6、脚本执行


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目录下查找。


以下是我收集到的比较好的学习教程资源,虽然不是什么很值钱的东西,如果你刚好需要,可以评论区,留言【777】直接拿走就好了

各位想获取资料的朋友请点赞 + 评论 + 收藏,三连!

三连之后我会在评论区挨个私信发给你们~

 

http://www.lryc.cn/news/180399.html

相关文章:

  • Rust :mod.rs和lib.rs中use的作用
  • ISP图像信号处理——平场校正介绍以及C++实现
  • 【深入了解Java String类】
  • 基于SpringBoot的知识管理系统
  • Pytorch基础:Tensor的reshape方法
  • 【数据库——MySQL】(13)过程式对象程序设计——存储函数、错误处理以及事务管理
  • Spring Boot的魔法:构建高性能Java应用
  • 如何做好测试?(七)兼容性测试 (Compatibility Testing, CT)
  • 经典循环神经网络(一)RNN及其在歌词数据集上的应用
  • docker+mysql+flask+redis+vue3+uwsgi+docker部署
  • Spring boot接收zip包并获取其中excel文件的方法
  • Ubuntu镜像源cn.arichinve.ubuntu.com不可用原因分析和解决
  • Java基础面试,String,StringBuffer,StringBuilder区别以及使用场景
  • 基于SpringBoot的高校学科竞赛平台
  • excel如何让线条消失,直接设置网格即可,碰到不方便的地方优先百度,再采取蛮干
  • 抖音短视频seo矩阵系统源代码开发系统架构及功能解析
  • 在pycharm中弹出图后,需要关闭才会显示Process finished with exit code 0
  • 【计算机网络笔记六】应用层(三)HTTP 的 Cookie、缓存控制、代理服务、短连接和长连接
  • Vue中的数据分页与分页组件设计
  • TCP串流场景剖析
  • Windows历史版本下载
  • 企业级磁盘阵列存储系统由硬到软全析
  • V4L2 驱动架构介绍
  • 掌握这些技巧,让Excel批量数据清洗变得简单高效!
  • 成都瀚网科技:抖音上线地方方言自动翻译功能
  • 【k8s】【docker】web项目的部署
  • 【视频去噪】基于全变异正则化最小二乘反卷积是最标准的图像处理、视频去噪研究(Matlab代码实现)
  • 国庆day3---网络编程知识点脑图整合
  • 链表经典面试题(六)
  • SM2签名算法中随机数K的随机性对算法安全的影响