一、为什么要进行分布式部署Jmeter
对于并发量很大的需求,如上万并发量,受到CPU和内存的限制,单机模拟场景是实现不了的,为了让JMeter提供更大的负载能力,须使用它的分布式机制,即多台机器同时产生负载的功能。
以下参数分析可用于配置负载分布台数的参考:通常,4G内存最多可达到2000左右的并发量。在1.4G Hz~3GHz 的CPU 、1GB 内存的 JMeter 客户端上,可以处理线程 100~300。但是Web Service 例外。XML处理是 CPU 运算密集的,会迅速消耗掉所有的CPU 。一般来说,以XML技术为核心的应用系统,其性能将是普通Web 应用的 10%~25% 。另外,如果所有负载由一台机器产生,网卡和交换机端口都可能产生瓶颈,所以一个JMeter 客户端线程数不应超过 100 。其实我们可以根据这个大概的情况自己调试一下,比如单机上放一个数量级的并发量 500、1000跑起来看看CPU的使用情况,最佳状态是CPU占有率不超过80%。
二、Jmeter分布式执行原理
1、Jmeter分布式测试时,选择其中一台作为调度机(master),其它机器做为执行机(slave or Agent)。
2、脚本在master的GUI打开,测试计划仅在master上部署即可,执行时,master GUI会把测试计划发送到每台slave上,slave 拿到脚本后就开始执行,slave执行时不需要启动自己的GUI。每一台jmeter远程服务器都执行相同的测试计划,jmeter不会在执行期间做负载均衡,每一台服务器都会完整地运行测试计划。
3、执行完成后,slave会把结果回传给master,master会收集所有slave的信息并汇总。
三、分布式集群的配置
在部署前请保证各slave机的防火墙处于关闭状态,master与各台slave都可以ping通
1、执行机(slave)配置:
(1)slave机上需要安装Jmeter和支持当前Jmeter版本的JDK。(有时在运行Jmeter时会提示JDK版本过低)
(2)添加环境变量:JMETER_HOME路径为bin目录的上一级目录
这样启动jmeter-server服务时,就只会看到Found ApacheJMeter_core.jar
(3)启动bin目录下的:jmeter-server.bat(Linux下是jmeter-server),启动成功如下图。
Windows:
Linux:
Linux下启动jmeter-server有时会报错,提示“为知的名称或服务”,如下图:
解决办法:
1、cat /etc/sysconfig/network查看本机的主机名
2、vi /etc/hosts添加一行本机ip跟主机名映射
(4)上图上标红的IP和端口会在master里配置时用到。IP就是slave机器IP,端口默认是1099,端口也可以自定义,这里我改成了1000和1100。
(5)多台slave的话,重复1~4步骤就好。
2、调度机(master)配置:
(1)找到Jmeter的bin目录下的配置文件jmeter.properties,修改如下配置:
remote_hosts=127.0.0.1:1000,192.168.182.130:1200,192.168.182.129:1100(多台slave之前用 "," 隔开)
(2)用Jmeter打开测试脚本,为了调试方便,可以为脚本添加“查看结果树”和“聚合报告”。
(3)打开Jmeter,选择运行→远程启动,可以依次点击远程启动中的slave来执行脚本,对应的slave命令行窗口上会看到启动的信息,全部启动的话可以选择远程全部启动。远程停止同理,也可以远程退出。
每一台slave都执行相同的测试计划,就是在master上设定好的测试计划。
slave向master回传信息时如果请求执行成功了则不回传具体每个请求的Response信息,当你用查看结果树查看结果时,只能看到取样结果是200,而响应数据里面是空的。
slave控制台信息:
四、自定义端口
1、在slave机的Jmeter的bin目录下,找到jmeter.properties文件,修改如下两个配置项,比如我这里修改为1200:
server_port=1200
server.rmi.localport=1200
2、启动slave机上的jmeter-server.bat,如下图,端口已经修改为:1200
3、修改master机器的jmeter.properties文件:
remote_hosts=127.0.0.1:1000,192.168.182.130:1200,192.168.182.129:1100
4、重启jmeter.bat,如下图,端口已经变了
五、其它说明
1、调度机(master)和执行机(slave)最好分开,由于master需要发送信息给slave并且会接收slave回传回来的测试数据,所以mater自身会有消耗,所以建议单独用一台机器作为mater。
2、参数文件:如果使用csv进行参数化,那么需要把参数文件在每台slave上拷一份且路径需要设置成一样的,Filename这里设定一下(最好放在bin目录下)。
3、每台机器上安装的Jmeter版本和插件最好都一致,否则会出一些意外的问题。
4、如果想要master也分担负载,让master自身也执行测试计划,需要把master 的 IP 和 端口也写到配置文件里,在远程启动前,也要把master的 jmeter-server.bat运行,这样master也能和其他slave一起执行测试计划了。