文章来源:https://www.cnblogs.com/puresoul/p/4844539.html html
在使用Jmeter进行性能测试时,若是并发数比较大(好比最近项目须要支持1000并发),单台电脑的配置(CPU和内存)可能没法支持,这时可使用Jmeter提供的分布式测试的功能。apache
1、Jmeter分布式执行原理:并发
一、Jmeter分布式测试时,选择其中一台做为调度机(master),其它机器作为执行机(slave)。分布式
二、执行时,master会把脚本发送到每台slave上,slave 拿到脚本后就开始执行,slave执行时不须要启动GUI,我理解它应该是经过命令行模式执行的。性能
三、执行完成后,slave会把结果回传给master,master会收集全部slave的信息并汇总。测试
2、执行机(slave)配置:spa
一、slave机上须要安装Jmeter,具体如何安装这里不详细介绍了。插件
二、添加环境变量:JMETER_HOME=D:\B_TOOLS\apache-jmeter-2.13,此处为你Jmeter的路径命令行
三、启动bin目录下的:jmeter-server.bat,启动成功以下图:线程
四、上图上标红的IP和端口会在master里配置时用到。IP就是slave机器IP,端口默认是1099,端口也能够自定义,这里我自定义为1000,这个后面会讲。
五、多台slave的话,重复1~4步骤就好。
3、调度机(master)配置:
一、脚本:简单的一个访问百度的脚本:
二、找到Jmeter的bin目录下jmeter.properties文件,修改以下配置,IP和Port是slave机的IP以及自定义的端口(这里端口我自定义为100,后面会讲如何自定义):
remote_hosts=10.13.223.202:1000,10.13.225.12:1000
多台slave以前用","隔开,我这配置了2台,能够看到标红的这个就是上面截图slave的IP和Port.
三、打开Jmeter,选择运行,有运程启动、运程所有启动两个选项:
四、选择远程启动-->10.13.225.12:1000
a) master结果,这里我只启动了10.13.225.12:1000这一台slave,因此只有一个结果(线程数和循环次数都是1):
b) slave控制台信息:
五、选择远程启动-->远程所有启动:
a) master结果,所有启动,我配置了2台slave,因此有两次执行结果:
4、自定义端口:
上面其实已经实现了Jmeter的分布式测试,这部分主要介绍下如何自定义slave端口:
一、slave:在slave机的Jmeter的bin目录下,找到jmeter.properties文件,修改以下两个配置项,好比我这里修改成1888:
server_port=1888
server.rmi.localport=1888
二、启动slave机上的jmeter-server.bat,以下图,端口已经修改成:1888
三、master:修改master机器的jmeter.properties文件:
remote_hosts=10.13.223.202:1000,10.13.225.12:1888
四、重启jmeter.bat,以下图,端口已经变了:
5、其它说明:
一、调度机(master)和执行机(slave)最好分开,因为master须要发送信息给slave而且会接收slave回传回来的测试数据,因此mater自身会有消耗,因此建议单独用一台机器做为mater。
二、参数文件:若是使用csv进行参数化,那么须要把参数文件在每台slave上拷一份且路径须要设置成同样的。
三、每台机器上安装的Jmeter版本和插件最好都一致,不然会出一些意外的问题。