性能测试第11课-分布式介绍

  • 为什么要做分布?

  • --原因:我们在做性能测试的过程中可能会遇到并发数量较大的情况

  • 并发数量较大是什么概念?

  • --一台电脑一般情况下http协议,jmeter智能产生1000~2000之间的并发用户数,超过2K一般就会产生不了

  • 被测系统性能越好,发起性能测试的电脑能产生的并发用户数就会越少,为什么?

  • --因为我们的电脑端口数量是有限的,最大为65535(2^32)个,我们每发起一次请求就会占用一个端口,然后端口释放,再利用但是端口释放是需要时间的。被测系统性能越好,响应的就会越快。如果响应时间小于端口释放时间。当发起方电脑的端口被全部占用时,端口就不够用了系统就会报错

  • 被测服务器支持的请求如果超过2K怎么办

  • 我们就需要多个机器一起来创建并发用户数,一起向服务器发起请求。

  • 我们用一台主控电脑master,控制多台电脑slave,一起想服务器发起请求

  • 性能测试中我们把这种操作叫做分布式 master-slave

  • slave助攻机(3个点)--修改配置文件(/bin/jmeter.properties)

  • server_port默认是1099,可以自己改 (自己定义端口),也可以不改,端口一般在[1024,65535]之间

  • server.rmi.port 改成和server_port相同的端口

  • rmi:认证

  • server.rmi.ssl.disable=true,这个一定要改,--我们不使用加密认证传输方式

助攻机器电脑配置

  • 启动slave机器

  • jmeter可以跨平台,所以我们的助攻机器可以是 mac/linux/windows系统

  • 但是不建议助攻机器混用,建议所有助攻机器用同一个系统

  • jmeter要在jre环境运行,而且使用jdk1.8,所以我们的助攻机器也要求jdk1.8

  • jmeter的版本和插件要求一致,我们有多台助攻机器,如果版本插件不一致,----他们的代码是有差异的,这样的话执行同一个请求可能存在差异。

  • 可以咋一个机器上打包,传给所有机器

  • jmeter-server -Djava.rmi.server.hostname=助攻机器ip --linux

  • jmeter-server.bat -Djava.rmi.server.hostname=助攻机器ip --windows

  • 操作(主控机windows+助攻机linux):

  • 在windows中修改jmeter.properties配置文件

  • 本地jmeter打包

  • 打开一个linux电脑,jdk1.8

  • 把jmeter的zip包上传到linux电脑(linux中安装的jdk必须要为1.8版本)

  • 解压指令 unzip XXX.zip

  • 校验jmeter文件的权限 查看 ls-lth,修改权限 chmod+x* 或者 chmod 111 *(不建议加上777权限)

  • 执行启动命令

  • 因为我们没有配置 JMETER_HOME环境变量,所以需要在bin目录下执行相关指令

  • linux

  • ./jmeter-server -Djava.rmi.server.hostname=当前虚拟机IP

  • windows

  • ./jmeter-server.bat -Djava.rmi.server.hostname=当前虚拟机IP

  • 运行前测试一下主机与助攻机器之间的网路是否连通

  • telnet + 空格 +jmeter.properties中设置的端口号,我这里是1099

主控电脑电脑参数配置(修改配置后要重启jmeter才生效)

  • master主机(3个点)--修改配置文件(/bin/jmeter.properties)

  • 修改remote_hosts 填写助攻 电脑的1的IP:端口号,助攻电脑2的IP:端口号……

  • 下图中如果用 - r运行则会同事运行所有已配置的助攻机

  • 如果用用-R +具体的IP运行则该条配置不生效

  • server.rmi.ssl.disable=true,这个一定要改,--我们不使用加密认证传输方式

  • mods=Standard ----开启标准模式,可改可不改

  • 如果开启了,那么在jmeterd的gui图像界面中可以看到分布式机器的运行结果

  • 如果没有开启,那么看不到

  • 远程启动:

  • 实际是远程调用了一下

  • 注意点:

  • 助攻机器只是用于产生并发用户数,并使用这些并发用户来执行脚本,脚本不是由助攻机器控制

  • 助攻电脑上是否有.jmx脚本都没关系

  • 但是,如果主控脚本中有csv数据文件设置,要求读取一个文件,那么助攻电脑上必须要有这个文件

  • 解决办法:在助攻机器启动,在助攻服务命令启动的路径下,要有需要读取的文件

  • 或者在 .jmx相同的路径下要有需要读取的文件

  • 如果有多个助攻机器,所有的助攻机器都完整复制主控机器的脚本场景来运行

  • 在用分布式的时候如果直接是用Ctrl+C 结束主控电脑的进程会出现什么问题

  • 在助攻电脑上使用Ctrl+C结束了主控进程,但是分布式机器并没有收到finish指令,所以分布式机器上的jmeter进程并没有结束

  • 当我们再次在主控电脑上使用分布式执行指令时,就会报分布式机器处于繁忙状态,连接不上

  • 链接被拒或者 分布式机器处于busy状态

  • 怎么解决以上问题:

  • 方法1:主控电脑发送结束指令

  • 方法2:重启助攻机器上的jmeter-server服务

  • 方法3:在繁忙的分布机器上执行以下指令,执行之后,分布式指令会停止,但是分布式服务不会停止----推荐这个方法

  • stoptest.sh ----linux/mac

  • stoptest.cmd ----windows

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值