压测工具笔记(二)之JMeter jmeter压测mq
csdh11 2024-12-20 14:07 22 浏览
@TOC
压测工具笔记(一)之主流工具:https://blog.csdn.net/weixin_42526326/article/details/121041125)
压测工具笔记(二)之JMeter:https://blog.csdn.net/weixin_42526326/article/details/121040719
JMeter是Apache下的一个顶级项目,一个功能强大压力测试工具
JMeter是一个纯java写的开源软件,用来测试可变行为和性能。起初它设计的目的是测试Web应用,但是现在已经扩展到其它的测试
JMeter既提供了GUI界面方便用户使用也提供了命令行的方式让用户操作
环境
- 下载[登录官网:http://jmeter.apache.org/download_jmeter.cgi),下载安装包或者解压包(推荐使用压缩包)低版本注意:5.4版本支持JDK1.8以及更高的版本
apache-jmeter-5.4.1.tgz |
apache-jmeter-5.4.1.zip |
- 安装/解压 安转目录文件说明bin:可执行脚本文件docs:JMeter提供的api的文档extras:额外的文件lib:JMeter本身所依赖的jar包licenses:JMeter依赖的jar包的licenseprintable_docs:JMeter的介绍和使用手册
- 配置环境变量也可以不配置,只是为了方便脚本使用电脑桌面-->右键选择“属性”--> 高级系统设置-->高级-->环境变量 新建系统变量JMETER_HOME = D:\Tools\apache-jmeter-5.4.1(安装路径)新建系统变量CLASS_PATH=%JMETER_HOME%\lib\ext\ApacheJMeter_core.jar; %JMETER_HOME%\lib\jorphan.jar;(在CLASS_PATH中的路径固定)配置系统变量PATH,加上%JMETER_HOME%\bincmd 控制台 命令 jmeter -v启动测试环境 cmd 控制台 命令 jmeter 直接可以启动
- 启动安装目录下启动程序(推荐桌面快捷或者jmeter脚本启动,默认为GUI模式) 启动成功 从这段提示我们至少可以知道两个信息:不要用GUI的模式进行测试,而应该用CLI模式(命令行,服务器一般不需要GUI)运行参数可以改变,但是不建议修改set HEAP=-Xms1g -Xmx1g -XX:MaxMetaspaceSize=256mOptions->Choose Language->Chinese(Simplified)切换成简体中文
HTTP接口测试
JMeter可以支持测试的应用/服务/协议有很多,目前主要介绍HTTP请求
接口测试的主体流程:创建测试计划,计划中创建线程组,线程组中创建线程HTTP请求,进行测试
- 测试计划(初始化会创建一个)
- 线程组右键TestPlan->添加->线程(用户)->线程组配置说明:线程数填10,Ramp-up时间填5,循环次数填1,就表示在5秒内执行一次,发送10次请求。
- HTTP请求右键Thread Group,添加->取样器->HTTP请求
填写请求配置:
方法选择GET,路径为url的请求路径,GET请求的参数可以直接带在路径上,也可以写到下面的参数那里,通过点击“添加”按钮来添加请求参数。
**配置请求头:**
添加->配置元件->HTTP信息头管理器
- 测试右键HTTP请求,添加->监听器->察看结果树右键HTTP请求,添加->监听器->聚合报告填写好以上的配置,选择需要的监听器,点击绿三角就可以进行进行测试,测试之后查看监听器,就会得到我们想要的结果监听器功能:
- 测试报告 报告解释:样本:请求的次数,计算公式是线程数*循环次数,如果线程组配置勾选了永远,那么就是你停止测试时实际发送的请求数平均值:响应时间的平均用时,单位是毫秒。比如这里的平均响应时间是38毫秒中位数:响应时间的中位数,单位是毫秒。90%百分位:90%的响应时间小于该数值,单位是毫秒。这里有90%的响应时间小于22毫秒95%百分位:含义和90%类似99%百分位:含义和90%类似最小值:本轮测试最小响应时间,单位是毫秒。最大值:本轮测试最大响应时间,单位是毫秒。异常%:本轮测试出现异常的请求比例。吞吐量:可以理解为QPS,即是我们测试的接口处理请求的能力。比如这里是平均每秒可以处理2.2次请求接收KB/Sec:响应数据的接收速率发送KB/Sec:请求数据的发送速率刚才只是简单地5秒10次请求,一般的接口都没有问题,当我们把线程数扩大百倍至1000,结果就不一定了。清除数据,重新测试:先点击界面上方的一个齿轮加两把扫帚的按钮来把结果树和聚合报告清除,然后再点击绿色的启动按钮,重新测试你会发现当并发增大时,会有一部分请求出现了异常。再切换到聚合报告上,你会发现原来平均响应时间只有30多毫秒直接飙到5秒多了,异常率也出现了。这时就需要我们根据一些错误信息去做一些调优了,可能是系统级别的,也可以是jvm级别的,又或者是代码本身的问题。这不是本篇所要讲的,这里就不说了。
JMeter进阶
- 自定义变量同postman一样,我们也可以在jmeter中创建测试的变量右键点击Thread Group,添加->配置元件->用户定义的变量,也可以在测试计划或者HTTP请求下创建,这样作用域就是整个测试计划或者HTTP请求。然后选择用户定义的变量,并在右边点击添加按钮,添加host和port两个变量:在JMeter中使用变量是通过${}来引用的,比如要引用host变量,就是${host},然后我们选择HTTP请求,把IP地址和端口改为引用变量的形式
- JMeter命令我们的服务器基本都是Linux系统,而我们的服务器应该不会安装GUI操作界面,因为这对于用来运行服务来说不但没用,还会吃掉很多cpu和内存资源,可能还会让服务器不稳定。这也是JMeter建议我们不要用GUI的方式去测试的原因。既然这样,为什么JMeter又要提供GUI界面呢,看回JMeter的启动控制台,有这样一行信息:jmeter -n -t [jmx file] -l [results file] -e -o [Path to web report folder]这里我们关注一个参数是-t,后面接jmx文件,这个文件就是上面保存的jmx文件,它保存了JMeter压测时需要的线程组、HTTP请求等配置参数。打开可以看到其实是一个xml格式的文件,里面有各种各样的参数,如果没有GUI界面,让用户去手写这么一个配置文件,那就很麻烦了。jmeter的完整参数可以通过jmeter -?查看,这里只介绍几个常用的参数:-n:非GUI模式,其实就是命令行的模式
-t:后跟测试文件(jmx文件)
-l:后跟log文件,把测试的过程输出到日志文件中
-e:测试结束后生成报告
-o:测试报告存放目录,必须是空目录下面的命令行完成后会在指定的目录生成html格式的测试报告,下面只展示index.html,打开它,就可以看到很漂亮的图形化的报告了,可以拿去给你们老板看了。jmeter -n -t "D:\Tools\apache-jmeter-5.4.1\bin\http\Test Plan.jmx" -l "D:\Tools\apache-jmeter-5.4.1\bin\http\Test Plan.log" -e -o E:\Game\jemeter_result - 分布式测试上面所介绍的是在一台机器上的操作,那么就会有这么一个问题:当你设置线程数为10时,在一台4核心cpu的机器上执行,这台机器模拟出10个线程当然没问题,但是假如你把线程数提升到10000,表面上这台机器也在努力地给你模拟10000个线程,但是它的核心数也只有区区4个,在底层其实还是操作系统在不断切换线程来模拟这10000个线程,线程切换需要时间,发送请求也需要时间,这样做的话除了让测试机的cpu使用率飙升到100%之外,还可以让你得到一份不准确甚至错误的数据,因为你的机器其实是没办法在5秒来把这10000个请求发送完毕的。这个时候我们就需要用多台机器去同时给接口机发送请求,这就是分布式测试。说一下大致的原理,我们准备多台机器,其中一台作为master机器,其余的作为slave机器,master机器用来发送指令,slave机器去执行,原理图如下:这些机器的要求如下:关闭防火墙或者打开响应的端口在同一个子网JMeter可以访问测试的接口JMeter的版本一致,JDK的版本也一致,否则可能出错必须为RMI设置SSL或者关闭它满足了以上的条件,先执行各个slave里bin目录下的jmeter-server,然后开发master机器上的JMeter的bin/jmeter.properties文件,找到remote_hosts=127.0.0.1那行,并且改为slave内网地址,地址之间用英文逗号分隔,然后打开master机器上的JMeter,像单机那样测试就可以了。
注意:
关闭前需要保存我们设置好的测试计划
问题: 保存测试脚本时只保存了Testplan下的部分节点,导致生成的测试脚本只是“testplan”下面的某些元素,,不包括需要运行测试所需的“TestPlan”元素。
解决方案: 在保存测试脚本时,保存整个测试计划,以下两种方式
1.在文件菜单中单击“保存测试计划”或“保存测试计划为”选项;
2.鼠标选中测试计划节点,直接点击工具栏上的“保存测试计划”按钮
专有名词说明:
专有名词 | 说明 |
TestPlan | 测试计划,相当于一个工程,需要测试什么,怎么测就是定义在一个测试计划中 |
Thread Group | 线程组,相当于模拟的请求数。一个线程相当于一个用户请求 |
察看结果树 | 监听发送请求时各个请求的状态 |
聚合报告 | 把一次测试的数据汇总 |
使用体验:
使用下来的第一感官是:工具功能强大,但是GUI做的是真的low,连自适应都没有。
相对来讲Windows风格的界面是最友好的一个了 选项-->-外观->Windows
参考:https://www.cnblogs.com/spareyaya/p/12807638.html
相关推荐
- OKHttp原理解析(okhttp的作用)
-
Okhttp应该是Android目前非常流行的第三方网络库,尝试讲解他的使用以及原理分析,分成几个部分:...
- 快速教会你优雅的解决TCP客户端端口耗尽的问题
-
Hello,我是Henry,相信各位开发老爷在使用大并发网络连接的时候,可能都遇到过TCP客户端端口耗尽的问题,这是一个常见问题,以下是系统性的解决方案及技术细节:1.理解端口限制的本质...
- 这3个接口基础知识,产品经理需要知道
-
产品经理在工作中,避免不了要阅读接口文档,希望本文能够帮助大家更好的了解接口。接口,即客户端(浏览器)向服务器提交请求,服务器向客户端返回响应。本质就是数据的传输与接收。本文主要介绍接口相关的基础知识...
- Java 11新特性对开发者的影响:让编程更高效、更自由
-
Java11新特性对开发者的影响:让编程更高效、更自由在这个瞬息万变的编程世界里,每一代Java的更新都承载着无数开发者对性能优化、生产力提升以及代码美感追求的期望。作为继Java8之后的首个长期...
- 干货-okHttp的优点-收藏了(okhttp的好处)
-
OkHttp相较于其它的实现有以下的优点.支持SPDY,允许连接同一主机的所有请求分享一个socket。如果SPDY不可用,会使用连接池减少请求延迟。使用GZIP压缩下载内容,且压缩操作对用...
- 如何在 Java 项目中集成 DeepSeek
-
一、使用官方SDK基础集成1.添加依赖(Maven)<dependency><groupId>com.deepseek</groupId>...
- spring cloud gateway 性能优化思路
-
SpringCloudGateway是一个高性能的API网关,但在实际的生产环境中,可能会遇到一些性能瓶颈。以下是一些SpringCloudGateway的性能优化方面:调整线程池...
- 你对Android中的okHttp的使用真的了解吗
-
框架下载地址:https://github.com/square/okhttp今天给大家讲解下网络框架okhttp的使用,这个框架非常强大,很多框架都用它来加载网络资源,目前很多开发者还在用As...
- 京东大佬问我,Nginx并发连接如何设置?详细说明
-
京东大佬问我,Nginx并发连接如何设置?详细说明首先,我需要回忆一下Nginx的并发模型。Nginx是基于事件驱动的异步架构,所以它的并发处理能力和配置参数有很大关系。主要的参数应该包括worker...
- 如何实现一个连接池?一文带你深入浅出,彻底搞懂
-
-前言-【2w1h】是技术领域中一种非常有效的思考和学习方式,即What、Why和How;坚持【2w1h】,可以快速提升我们的深度思考能力。...
- Golang 网络编程(golang 系统编程)
-
TCP网络编程存在的问题:拆包:对发送端来说应用程序写入的数据远大于socket缓冲区大小,不能一次性将这些数据发送到server端就会出现拆包的情况。通过网络传输的数据包最大是1500字节,当TCP...
- Spring6|Spring Boot3有哪些HTTP客户端可以选择
-
个人博客:无奈何杨(wnhyang)个人语雀:wnhyang...
- 10. 常用标准库(标准库有哪些)
-
本章深入解析Go语言核心标准库的关键功能与生产级应用技巧,结合性能优化与安全实践,提供高效开发指南。10.1fmt/io/os10.1.1fmt高级格式化...
- Nginx之连接池(nginx 长连接 连接复用)
-
我们知道Nginx利用连接池来增加它对资源的利用率。下面我们一起来看看Nginx是如何使用连接池的。从上一节模块开始已经慢慢会接触一些Nginx的源码部分来。每个worker进程都有一个独立的ngx...
- 开发者必备的Android开发资源之OkHttp
-
小编在这里给各位Android开发者介绍的资源包括工具、库和网站等。有效地利用它们,将有助于减轻我们的工作量,提高我们的工作效率。为什么需要一个HTTP库Android系统提供了两种HTTP通信类,H...
- 一周热门
- 最近发表
- 标签列表
-
- mydisktest_v298 (34)
- document.appendchild (35)
- 头像打包下载 (61)
- acmecadconverter_8.52绿色版 (39)
- word文档批量处理大师破解版 (36)
- server2016安装密钥 (33)
- mysql 昨天的日期 (37)
- parsevideo (33)
- 个人网站源码 (37)
- centos7.4下载 (33)
- mysql 查询今天的数据 (34)
- intouch2014r2sp1永久授权 (36)
- 先锋影音源资2019 (35)
- jdk1.8.0_191下载 (33)
- axure9注册码 (33)
- pts/1 (33)
- spire.pdf 破解版 (35)
- shiro jwt (35)
- sklearn中文手册pdf (35)
- itextsharp使用手册 (33)
- 凯立德2012夏季版懒人包 (34)
- 冒险岛代码查询器 (34)
- 128*128png图片 (34)
- jdk1.8.0_131下载 (34)
- dos 删除目录下所有子目录及文件 (36)