jmeter 之性能分布式压测
背景:
当并发量达到一定数量时,单台测试设备不足以支撑,甚至会出现内存溢出等情况,解决这个问题就可用分布式测试,使用多台测试设备来达到更大的用户并发数。
原理:
1.一台设备作为调度机(master),其他设备作为执行机(slave)
2.执行时,调度机会将脚本发送到执行机,执行机收到脚本后开始执行。
3.执行结束后,执行机会将结果回传到调度机,调度机将收集所有执行机结果信息
环境配置:
1.调度机配置:
进入调度机jmeter/bin目录下(eg:apache-jmeter-5.1.1\bin),打开jmeter.properties文件修改remote_hosts配置,IP地址为执行机IP+端口号(默认1099,可修改),调度机也可作为执行机,即将调度机IP配在remote_hosts,多个执行机间以英文逗号分开(,)
#--------------------------------------------------------------------------- # Remote Hosts - comma delimited
remote_hosts=172.16.40.89:1099, 172.16.40.159:1099
#remote_hosts=localhost:1099,localhost:2010 # RMI port to be used by the server (must start rmiregistry with same port)
#server_port=1099
将 server.rmi.ssl.disable=false 改为true
#server.rmi.ssl.truststore.password=changeit
#
# Set this if you don't want to use SSL for RMI
server.rmi.ssl.disable=true
#---------------------------------------------------------------------------
# Include Controller
#---------------------------------------------------------------------------
2.执行机配置:
进入执行机jmeter/bin目录下(eg:apache-jmeter-5.1.1\bin),打开jmeter.properties文件修改remote_hosts配置,IP地址为本机IP+端口号(默认1099,可修改)
#--------------------------------------------------------------------------- # Remote Hosts - comma delimited
remote_hosts=172.16.40.159:1099
#remote_hosts=localhost:1099,localhost:2010 # RMI port to be used by the server (must start rmiregistry with same port)
将 server.rmi.ssl.disable=false 改为true
#server.rmi.ssl.truststore.password=changeit
#
# Set this if you don't want to use SSL for RMI
server.rmi.ssl.disable=true
#---------------------------------------------------------------------------
# Include Controller
#---------------------------------------------------------------------------
GUI启动执行:
1.远程启动单个执行
调度机端进入bin目录中双击ApacheJMeter.jar文件/jmeter.bat文件,打开jmeter界面->运行->远程启动,此时可见设置的执行机->选中某个执行机启动

以上操作出现错误:
Connection refused to host: 172.16.40.159; nested exception is:
java.net.ConnectException: Connection refused: connect
错误原因:
执行机未启动jmeter-server
解决方法:
在对应的执行机中启动jmeter-server(linux 执行jmeter-server文件, windows 执行jmeter-server.bat文件),开启后在调度机上再次远程启动该执行机,并启动脚本

2.远程启动所有
调度机端进入bin目录中双击ApacheJMeter.jar文件,打开jmeter界面->运行->远程启动所有

以上操作出现错误:
Engine is busy - please try later
问题原因:
执行机已被启动,未停止,再次启动就会出错
解决方法:
远程关闭/停止所有执行机或者关闭已开启的执行机再次执行不会出现以上错误

Engine is busy - please try later 问题解决后,再次远程启动所有,此时出现错误:(只要出现以下问题就是服务器之间没有连通)
Error in rconfigure() method java.rmi.ConnectException: Connection refused to host: 172.16.40.159; nested exception is:
java.net.ConnectException: Connection refused: connect
问题原因:
vm中docker 机子ip 端口只对外网开放了1099.当启动如下命令去启动执行机,会每次跳不同的端口,所以没有办法启动执行机.需要指定端口
.\jmeter-server -Djava.rmi.server.hostname=172.16.40.159 (win10系统用.\)
解决方法:
进入执行机jmeter/bin目录下(eg:apache-jmeter-5.1.1\bin),打开jmeter.properties文件修改remote_hosts配置如下:
# RMI port to be used by the server (must start rmiregistry with same port)
server_port=1099 # To change the default port (1099) used to access the server:
#server.rmi.port=1234
server.rmi.port=1099 # To use a specific port for the JMeter server engine, define
# the following property before starting the server:
#server.rmi.localport=4000
server.rmi.localport=1099
配置后此时执行机重启jmeter-server,调度机重启jmeter再次远程启动所有

当脚本中存在读取外部参数化文件(csv),远程启动所有,未报错,但执行机未执行脚本,查看log显示
2022-05-12 14:28:43,191 INFO o.a.j.g.u.JMeterMenuBar: setRunning(true, 172.16.40.159:1099)
2022-05-12 14:28:43,215 INFO o.a.j.e.ClientJMeterEngine: sent test to 172.16.40.89:1099 basedir='.'
2022-05-12 14:28:43,215 INFO o.a.j.e.ClientJMeterEngine: Sending properties {}
2022-05-12 14:28:43,218 INFO o.a.j.e.ClientJMeterEngine: sent run command to 172.16.40.89:1099
2022-05-12 14:28:43,218 INFO o.a.j.e.DistributedRunner: Remote engines have been started
2022-05-12 14:28:43,221 INFO o.a.j.g.u.JMeterMenuBar: setRunning(true, 172.16.40.89:1099)
2022-05-12 14:28:43,254 INFO o.a.j.g.u.JMeterMenuBar: setRunning(false, 172.16.40.89:1099)
2022-05-12 14:28:43,328 INFO o.a.j.g.u.JMeterMenuBar: setRunning(false, 172.16.40.159:1099)
原因:
当脚本中存在读取外部参数化文件(csv,txt),未将外部文件上传到执行机
解决办法:
a.不涉及跨平台:
将脚本中需要用到的外部文件都上传到执行机jmeter下的bin目录中(涉及到分布式压测时,csv配置路径一般都设置为相对路径)

文件上传到执行机后再次启动所有:

b.涉及跨平台:
查看jmeter属性:测试计划->添加->非测试元件->属性显示


查看system属性:user.dir,file.separator
file.separator


linux查看属性步骤如上
windows、linux系统的user.dir,file.separator是不一样的,此时可通过函数助手中 __P读取不同平台、不同 Jmeter 安装路径,自动获取 Jmeter 运行路径,然后通过拼接方式配置csv文件读取路径${__P(user.dir,)}${__P(file.separator,)}webadmin.csv,配置OK后,外部文件只需要上传到执行机的jmeter/bin目录下(linux、windows适用)


命令启动执行:
windows
jmeter -n -t D:\API\性能调优.jmx -r -l result.jtl # 启动所有执行机
jmeter -n -t D:\API\性能调优.jmx -r 172.16.40.159 -l result.jtl # 启动指定执行机
jmeter -n -t D:\API\性能调优.jmx -r -l result1.jtl -e -o test # 启动所有执行机,并生成报告
jmeter 之性能分布式压测的更多相关文章
- jmeter 分布式压测(windows)
单台压测机通常会遇到客户端瓶颈,受制于客户机的性能.可能由于网络带宽,CPU,内存的限制不能给到服务器足够的压力,这个时候你就需要用到分布式方案来解决客户机的瓶颈,压测的结果也会更加接近于真实情况. ...
- 性能工具之JMeter+InfluxDB+Grafana打造压测可视化实时监控【转】
概述 本文我们将介绍如何使用JMeter+InfluxDB+Grafana打造压测可视化实时监控. 引言 我们很多时候在使用JMeter做性能测试,我们很难及时察看压测过程中应用的性能状况,总是需要等 ...
- jmeter实现分布式压测步骤
环境说明:安装与控制机相同版本的jdk与jmeter 1.修改控制机中的jmeter.properties文件 将<remote_hosts=127.0.0.1>改为<remote_ ...
- jmeter(二十七)分布式压测注意事项
之前的博客:jemter(二十三):分布式测试简略的介绍了利用jmeter做分布式测试的方法,当时只是介绍了背景和原因,以及基本的配置操作,有同学说写得不够详细. 正好今年双十一,我司的全链路压测,也 ...
- jmeter之分布式压测
很多性能大牛说一台机器的压测其实不准确,于是搜索网上的分布式压测练习了一番 目录 1.环境准备 2.控制机和压测机配置 3.执行分布式压测 1.环境准备 1.1准备一台windows作为控制机(mas ...
- JMeter分布式压测实战(2020年清明假期学习笔记)
一.常用压力测试工具对比 简介:目前用的常用测试工具对比 1.loadrunner 性能稳定,压测结果及颗粒度大,可以自定义脚本进行压测,但是太过于重大,功能比较繁多. 2.Apache ab(单接口 ...
- jmeter进行分布式压测过程与 注意事项
jmeter命令行运行但是是单节点下的, jmeter底层用java开发,耗内存.cpu,如果项目要求大并发去压测服务端的话,jmeter单节点难以完成大并发的请求,这时就需要对jmeter进行分布式 ...
- jmeter分布式压测
stop.sh需要跑Jmeter的服务器上安装Jmeteryum install lrzsz 安装rz.sz命令rz jemter的压缩包 拷贝到/usr/local/tools下面unzip apa ...
- jmeter 分布式压测(Linux)
之前一篇博文写的是如何在Linux上使用jmeter压测,这篇介绍下Linux上jmeter的分布式压测. 和windows上的分布式类似,需要配置agent节点和控制机 一.Agent节点配置 1. ...
随机推荐
- c#-03关于类和继承的基本知识
一.类继承 通过类继承可以定义一个新类,新类纳入一个已经声明的类进行扩展 已经存在的类叫做基类,而通过继承出的类叫做派生类,派生类的组成为: 本身声明中的成员 基类的成员 派生类无法删除基类成员,但可 ...
- 洛谷P3870 [TJOI2009] 开关 (线段树)
简单的省选题...... 打异或标记即可. 1 #include<bits/stdc++.h> 2 const int N=2e5+10; 3 using namespace std; 4 ...
- 🔥支持 Java 19 的轻量级应用开发框架,Solon v1.10.4 发布
Java 轻量级应用开发框架.可用来快速开发 Java 应用项目,主框架仅 0.1 MB. 相对于 Spring Boot 和 Spring Cloud 的项目: 启动快 5 - 10 倍. (更快) ...
- 齐博x1页面不直接报错,如何排查
有的页面是不会直接报错的,比如像下面这个,这个时候需要你用谷歌或火狐浏览器打开,按F12键进入开发者模式,然后选择Network选项,刷新一下当前的网页,就会看到红色的请求.单独打开他.就可以看到错误 ...
- 0025:2011年NOIp普及组真题——瑞士轮题解
题目链接:https://www.luogu.com.cn/problem/P1309 如果是新手可能马上会想到sort排序,每比一次就排一次,但是这样的时间复杂度有点高,只有60分: 这是因为每次比 ...
- Go | 基本数据类型的相互转换
基本数据类型的相互转换 Go在不同类型的变量之间赋值时需要显示转换,不能自动转换 基本语法 表达式 T(v): 将值v转换成类型T T就是数据类型: int32, int64, float32... ...
- 通过tkinter列出全部字体名称
通过tkinter列出windows系统全部字体名称 通过 tkinter.font 的 families() 函数实现 import tkinter import tkinter.font # 把p ...
- vue-axios增加操作
<template> <div class="Insert"> <label for="name">名称:</labe ...
- 部署owncloud连接ladp迁移数据
定期 清理日志 echo '' > /var/www/html/data/owncloud.log 查询 用户 的 ldap 语句 (|(objectclass=inetOrgPerson)(o ...
- 如何使用ModelBox快速提升AI应用性能?
摘要:在开发初期开发者往往聚焦在模型的精度上,性能关注较少,但随着业务量不断增加,AI应用的性能往往成为瓶颈,此时对于没有性能优化经验的开发者来说往往需要耗费大量精力做优化性能,本文为开发者介绍一些常 ...