在使用Jmeter进行性能测试时,如果并发数比较大(比如最近项目需要支持1000并发),单台电脑的配置(CPU、内存、IO等)可能无法支持,这时可以使用Jmeter提供的分布式测试的功能。
一、Jmeter分布式执行原理:
1、Jmeter分布式测试时,选择其中一台作为调度机(master),其它机器做为执行机(slave)。
2、执行时,master会把脚本发送到每台slave上,slave 拿到脚本后就开始执行,slave执行时不需要启动GUI,我理解它应该是通过命令行模式执行的。
3、执行完成后,slave会把结果回传给master,master会收集所有slave的信息并汇总。
二、执行机(slave)配置:
1、关闭电脑防火墙,安装jmeter
2、jmeter.properties
关闭SSL: server.rmi.ssl.disable=true
3、system.properties
java.rmi.server.hostname=10.13.225.12 (配置当前电脑的ip地址)
4、端口号:端口号默认是tcp 1099
可以进行自定义,自定义步骤如下:
(1)在slave机的Jmeter的bin目录下,找到jmeter.properties文件,修改如下两个配置项,比如我这里修改为1888:
server_port=1000
server.rmi.localport=1000
(2)启动slave机上的jmeter-server.bat,如下图,端口已经修改为:1000
5、运行jmeter-server
注:多台slave的话,重复1~5步骤就好。
三、调度机(master)配置:
1、关闭电脑防火墙,安装jmeter
2、jmeter.properties
关闭SSL: server.rmi.ssl.disable=true
添加负载机ip:remote_hosts=10.13.223.202:1000,10.13.225.12:1000 (IP和Port是slave机的IP以及自定义的端口)
多台slave之前用","隔开,我这配置了2台,可以看到标红的这个就是上面截图slave的IP和Port.
3、打开Jmeter,选择运行,有运程启动、运程全部启动两个选项:
4、选择远程启动-->10.13.225.12:1000
a) master结果,这里我只启动了10.13.225.12:1000这一台slave,所以只有一个结果(线程数和循环次数都是1):
b) slave控制台信息:
5、选择远程启动-->远程全部启动:
a) master结果,全部启动,我配置了2台slave,所以有两次执行结果:
来源博客:
https://www.cnblogs.com/puresoul/p/4844539.html