千家信息网

jmeter分布式测试

发表于:2024-11-21 作者:千家信息网编辑
千家信息网最后更新 2024年11月21日,作为一个纯 JAVA 的GUI应用,JMeter对于CPU和内存的消耗还是很惊人的,所以当需要模拟数以千计的并发用户时,使用单台机器模拟所有的并发用户就有些力不从心,甚至还会引起JAVA内存溢出的错误
千家信息网最后更新 2024年11月21日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远程启动测试中出现结果的响应数据为空,原因是:

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


代理 机器 服务器 服务 控制 运行 测试 文件 目录 控制器 变量 命令 用户 成功 地址 环境 分布式 两个 内存 工具 数据库的安全要保护哪些东西 数据库安全各自的含义是什么 生产安全数据库录入 数据库的安全性及管理 数据库安全策略包含哪些 海淀数据库安全审计系统 建立农村房屋安全信息数据库 易用的数据库客户端支持安全管理 连接数据库失败ssl安全错误 数据库的锁怎样保障安全 如何把数据上传到云服务器计算 oracle数据库免费的是哪个 服务器的操作系统的自锁功能 cbd 软件开发 惠普服务器哪个质量好 2个数据库实时同步技术 海曙安卓软件开发设计 百度在线网络技术沈阳 我的数据库怎么防止用户下载 艺蜂网网络技术有限公司招聘 软件开发一般需要几个人 数据库怎么修改本地服务器名称 南航网络安全实训报告 易商通网络技术有限公司 国土系统软件开发公司 医院网络安全现状分析 新建图书数据库的操作语句 计算机网络技术的拼音 怀孕离服务器的安全距离 网络安全黑板报设计感手机壳 携手合作共筑网络安全防线 魔域找不到数据库 利用知识图谱做网络安全 软件开发是否需要预批准 网络安全风险隐患专项排查报告 购买云服务器前要做的三件事 广东服务器维修多少钱 给一个数据库建表 sql数据库搜索查询软件 网络安全宣传教育活动简报
0