jmeter分布式测试

简介:

作为一个纯 JAVA GUI应用,JMeter对于CPU和内存的消耗还是很惊人的,所以当需要模拟数以千计的并发用户时,使用单台机器模拟所有的并发用户就有些力不从心,甚至还会引起JAVA内存溢出的错误。


不过,JMeter也可以像 LoadRunner 一样通过使用多台机器运行所谓的代理来分担负载产生器自身的压力,并借此来获取更大的并发用户数,我们只需手动配置一下即可。


1、在所有期望运行JMeter作为负载产生器的机器上安装JMeter,并确定其中一台机器作为控制器,其他的机器作为代理。下面示例中我们以windows服务器为控制器,另两台linux服务器作为代理。


然后运行所有代理机器上的JMeter-server.bat文件(linux服务器上运行Jmeter-server


假定我们使用两台机器172.16.129.155172.16.129.43作为代理




2、在作为Controller控制的windows机器上的操作:


Controller控制机器的JMeter安装目录下找到 bin 目录,找到 jmeter.properties 这个文件,使用记事本或者其他文字编辑工具打开它;



在打开的文件中查找remote_hosts=”这个字符串,找到这样一行“remote_hosts=127.0.0.1”。其中的 127.0.0.1 表示运行JMeter代理的机器,把它修改为我们需要用到的slave代理机器的ip地址加默认端口号1099:这里需要修改为

remote_hosts=172.16.129.155:1099,172.16.129.43:1099(两台代理服务器之间用,隔开)


再把下面几项去掉前面的注释(#):


server_port=1099


client.rmi.localport=0


server.rmi.port=1234


server.rmi.localport=1099


然后保存文件。



Controller控制机器的JMeter安装目录下找到 bin 目录,再找到 jmeter.bat 这个文件,使用记事本等其他文字编辑工具打开它;


新增set rmi_host=-Djava.rmi.server.hostname=本机ip(控制器ip

修改

Set ARGS=%DUMP% %HEAP% %NEW% %SURVIVOR% %TENURING% %PERM% %DDRAW% %rmi_host%



然后保存。



3、在作为代理服务器linux服务器上的操作:


修改bin目录下的jmeter-server文件,


去掉#

RMI_HOST_DEF=-Djava.rmi.server.hostname=172.16.129.155

(避免了虚拟机中出现的两个ip的情况


PS:

代理服务器中的hostname/etc/hosts里面ip地址对应的hostname要一致


然后保存。



对要进行分布式测试代理机器上需要添加jmeter环境变量:


命令 vim /etc/profile

insert

在文档最后,添加:

export PATH="/jmeter/apache-jmeter-2.12/bin:$PATH"

esc : w q

保存,退出,然后运行:

#source /etc/profile

不报错则成功。


运行env命令查看全部环境变量,看jmeter环境是否安装成功。(或者输入jmeter -v命令


windows上相当于添加用户变量JMETER_HOMEd:\jmeter,系统变量中的path中添加d:\jmeter\bin。)


bin目录下输入命令

chmod 777 jmeter-server

chmod 777 jmeter

防止权限禁止denied


4、确定代理服务器都可以ping到所需要测试的接口的机器,然后启用所有代理服务器上的jmeter-server


如图为成功启动代理服务器上的jmeter-server


启动控制器机器上的JMeter,并进入启动 ->远程启动菜单项。就会看到我们刚才添加的两个代理的地址,选中即可运行,如果想同时启动所有代理,选择远程全部启动即可。


控制器上的jmeter会收到指示


代理机上开始测试和完成测试的指示


5、注意结果

JMeter远程启动测试中出现结果的响应数据为空,原因是:

分布式测试中,通过远程启动代理服务器,注重的而是高并发,默认查看结果树中的响应数据为空,只有错误信息会被报回。




本文转自 32氪 51CTO博客,原文链接:http://blog.51cto.com/10672221/1950378
相关文章
|
3天前
|
Java 测试技术 Linux
jmeter-分布式部署之负载机的设置
jmeter-分布式部署之负载机的设置
169 1
|
6月前
|
Java 测试技术 Apache
用JMeter做接口压力测试
JMeter是Apache组织开发的基于Java的压力测试工具,它是用 Java 语言编写的
67 0
|
6月前
|
测试技术
JMeter压力测试简单例子
JMeter压力测试简单例子
71 0
|
6月前
|
Java 测试技术 Apache
Mac 下安装压力测试工具JMeter
Mac 下安装压力测试工具JMeter
230 0
|
6月前
|
消息中间件 弹性计算 Java
使用阿里云性能测试工具 JMeter 场景压测 RocketMQ 最佳实践
使用阿里云性能测试工具 JMeter 场景压测 RocketMQ 最佳实践
|
8月前
|
XML 前端开发 测试技术
使用 jMeter 对 SAP Spartacus 进行并发性能测试
使用 jMeter 对 SAP Spartacus 进行并发性能测试
76 0
|
3天前
|
数据可视化 Java 测试技术
JMeter 如何实现 Elasticsearch 8.X 性能测试?
JMeter 如何实现 Elasticsearch 8.X 性能测试?
20 0
|
3天前
|
JSON 网络协议 Java
使用Jmeter进行功能和性能测试
使用Jmeter进行功能和性能测试
|
3天前
|
SQL Java 测试技术
Jmeter的安装与快速使用(做并发测试)
Jmeter的安装与快速使用(做并发测试)
21 0
|
3天前
|
存储 测试技术 C++
P2P网络下分布式文件共享场景的测试
P2P网络下分布式文件共享场景的测试
124 6

热门文章

最新文章