困扰很多人的分布式性能测试,原来如此简单!

本贴最后更新于 302 天前,其中的信息可能已经物是人非

前言

我经常会遇到一些学生跟我聊性能测试工具Jmeter不好用,我问为什么不好用,他说压力稍微大一些就上不去报错了。一看报错信息就是地址被占用了。

图片.png

这就是典型的分布式的需求了。如果做性能测试,这个基本的问题都不会解决的话,那么表示性能测试你还没有入门哦!

性能测试为什么需要分布式?

我们做性能测试的工具Jmeter是安装在电脑或者服务器机器上的,不管是windows的电脑还是Linux系统机器,能够被使用的端口都是有限的,理论上的最大值 65535个,但是实际上都还到不了这个值:

然而,我们接口发送请求所用的协议是HTTP协议,这个协议特点:

而实际项目有可能接口性能比较好,能超过2000并发用户数,这就会超过1个Jmeter客户端能产生的并发用户数。这个时候,我们就需要通过增加Jmeter的机器来产生更多的并发用户数。这就是分布式。

分布式的原理

按照上面讲的分析,分布式就是为了增加客户机对服务器执行并发请求,突破单个机器的瓶颈。分布式的配置图如下:

图片.png

所以,性能测试脚本只需要管理者在主控制机上维护和修改变更就可以。假设管理者把线程数变了。每个助攻机的执行者就都按照新的线程数来产生并发用户数。

分布式环境搭建

前提条件准备:
助攻机的配置:

修改Jmeter的配置文件:jmeter.properties

完成这些修改,并保存文件,助攻机器的配置完成。保证每台助攻机器都同样的配置。

主控机的配置:

修改配置文件:jmeter.properties

确认模式:mode=Standard 这个属性,主控和助攻机器之间,使用通用的标准的数据交换方式。

注意: 修改属性配置文件,一定要保存文件,然后重启jmeter才生效
启动助攻机,启动命令:

windows:jmeter-server.bat -Djava.rmi.server.hostname=机器ip

**linux: **./jmeter-server -Djava.rmi.server.hostname=192.168.88.134

配置完成后,可以在jmeter图形界面中,看到助攻机器传回来的数据。

图片.png

点击上图的启动远程可以启动主动机开始跑脚本。可以启动部分,也可以同时启动所有助攻机跑脚本。如此就完美解决了一台客户机运行报错压力上不去的问题。

回帖
请输入回帖内容 ...