Jmeter压测过程当中,因为测试机配置有限,CPU、内存均可能是存在瓶颈。若是使用很大的并发进行测试时,就可能会感到程序比较卡,这时候就没法继续增长压力了。java
解决方法:linux
搭建Jmeter分布式集群,远程启动测试。apache
步骤以下:windows
一、在分布式集群中,脚本编辑、控制的机器叫作“client”,实际运行Jmeter测试脚本,负责向被测服务器发请求的机器,称为“server”。网络要求server和client须要网络互通。找几台机器做为 server,而后client和server相互ping彼此的ip地址,若是能ping通,说明网络是ok的。服务器
二、和client同样,server能够是linux系统,也能够是windows系统。
网络
在本文演示中,做为client机器,ip是172.31.132.242。并发
做为server机器,ip是172.17.3.212。分布式
三、演示中,由于server是linux系统的,咱们须要去官网下载linux系统对应的JMeter安装文件,解压便可。测试
进入安装目录:apache-JMeter-2.13/bin下,启动server端程序,执行:./JMeter-server (windows下启动JMeter-server.bat)spa
若是server机器有多个ip,启动的时候能够指定一个,如:
./JMeter-server-Djava.rmi.server.hostname=172.17.3.212
配置和启动client端安装目录的bin文件夹下,找到JMeter.properties文件
打开文件,并找到remote_hosts=127.0.0.1这一行,修改成server服务器的列表,以下所示,若是server有多个,那么多个机器地址之间使用英文逗号分隔:
其实,client本身能够同时做为一个server机器,向服务端发送请求(前提是client上也启动了JMeter-server程序),因此也能够把client的ip加上,添加本身只须要写127.0.0.1便可。
若是client有多个ip,也能够在启动的时候指定一个。 若是是windows系统,能够修改jmeter.bat启动脚本写明client这台机器的ip地址便可。
修改完毕后保存,启动Jmeter,打开界面。
执行分布式测试
打开client端的JMeter界面,点击运行-远程启动,里面能看到配置好的server端的机器列表。
此时能够启动一个远程机器,也能够选择下面的“远程所有启动”,同时启动全部的server。 点击后,client端会自动和server端的服务创建链接,下发测试脚本到server端; 等server端的测试所有结束后,会将测试结果汇总到client端,咱们在client端配置的监听器就能看到测试结果了。