postman导入请求到jmeter进行简单压测,开发同学一学就会
liuian 2025-01-04 21:27 52 浏览
背景#
这个事情也是最近做的,因为线上nginx被我换成了openresty,然后接入层服务也做了较大改动,虽然我们这个app(内部办公类)并发不算高,但好歹还是压测一下,上线时心里也稳一点。
于是用jmeter简单压测下看看,这里记录一下。
这次也就找了几个接口来压:登录接口、登录后获取用户信息接口、登录后写数据的一个接口。
因为这几个接口,在postman里面有,我就懒得手工录入到jmeter了(那种form表单,懒得一个一个弄),唯一需要解决的就是,能不能把postman里面的请求导出,然后导入到jmeter里面。
postman请求导入jmeter#
postman导出#
简单提一句,如果请求在postman里没有,也可以用抓包方式(charles、fiddler),在charles里将请求导出为curl格式,然后导入到postman里面。
postman导入jmeter的方式也比较简单,网上有人写了个开源库来做这个事情。
先导出:
最终会得到一个json文件。
转换json文件为jmeter的jmx#
使用了开源库,也是java写的:
https://github.com/Loadium/postman2jmx
我用的时候,因为我postman里面有个请求有点问题,导致报了空指针,然后自己debug了下,解决了,所以大家可以拉我的仓库也行:
https://github.com/cctvckl/postman2jmx
我也顺便给原仓库提了个pr。
使用方式:
Copy$ git clone https://github.com/Loadium/postman2jmx.git
$ cd postman2jmx
$ mvn package
$ cd target/Postman2Jmx
$ java -jar Postman2Jmx.jar my_postman_collection.json my_jmx_file.jmx
正常的话,最终就会得到一个my_jmx_file.jmx文件,导入jmeter即可。
jmeter配置#
导入效果#
打开这个jmx后,个人做了一点点修改,加了个查看结果数,改了下线程组配置,大概如下:
我这边项目还是依赖cookie 机制的,所以我这边就用了cookie manager,它会自动把返回中的set-cookie,存储到该线程的cookie区域,后续的请求也会自动携带:
如果不了解,可以在该页面点击Help,就能看到帮助文档。
导入的效果还是挺好的:
线程组中并发线程数的设置#
一般来说,压测的话,我们会关注某个接口的qps或tps,此时一般要增加一个listener,如聚合报告,来查看最终接口的吞吐(tps):
我们一般用jmeter做压测的目的,是我需要压测出,在目前架构、环境下,该接口的极限是多少,能达到多少笔/s,此时,就是靠不断地加压(比如提高并发用户数),在压力越来越大的情况下,系统一开始可能Throughput的值是一路增加的,但慢慢地,会到达一个拐点,到了这个点,你再加压,Throughout也不会继续增加了,此时,就拿到了极限tps。
当然,我们也可能加压到一定程度,发现接口的tps达标了,就不管了,不会继续加压,去寻找那个压力不断提升下的tps拐点。
但是,我之前一直有个问题,就是不知道jmeter里的并发线程数怎么设置,经过查阅,发现在性能测试领域,业内一般把这个值叫做 VU(virtual user)。
这个值,性能测试人员在做测试计划的时候,就会先去根据系统的使用人员规模、系统的高峰时间有多长,来进行估算,总的来说,还是有点复杂。我这边也是看了一本书,全栈性能测试修炼宝典,里面第7章讲了具体怎么算。
我这边也网上简单查了下,比如:
https://www.cnblogs.com/gltou/p/15168252.html
Copy通用公式
对绝大多数场景,我们用:
并发量=(用户总量/统计时间)*影响因子(一般为3)来进行估算。
#用户总量和统计时间使用2/8原则计算,即80%的用户集中在20%的时间
#影响因子,一般为3,根据实际情况来
#通用公式使用了二八原则,计算的并发量即是峰值并发量。
例子
以乘坐地铁为例子,每天乘坐人数为5万人次,每天早高峰是7到9点,晚高峰是6到7点,根据2/8原则,80%的乘客会在高峰期间乘坐地铁,则每秒到达地铁检票口的人数为50000*80%/(3小时*60*60s)=3.7,约4人/S,考虑到安检,入口关闭等因素,实际堆积在检票口的人数肯定比这个要大,假定每个人需要3秒才能进站,那实际并发应为4人/s*3s=12,当然影响因子可以根据实际情况增大!
它这个地铁的例子中,算出来并发用户就应该设置为12.
然后,另一个文章里的例子,这种是根据PV来计算:
Copy根据PV计算
并发量=(日PV/统计时间)*影响因子(一般为3)
#日PV和统计时间使用2/8原则计算,即80%的用户集中在20%的时间
#影响因子,一般为3,根据实际情况来
#PV公式使用了二八原则,计算的并发量即是峰值并发量。
例子
比如一个网站,每天的PV大概1000w,根据2/8原则,我们可以认为这1000w,pv的80%是在一天的9个小时内完成的(人的精力有限),那么TPS为:1000w*80%/(9*60*60)=246.92个/s,取经验因子3,则并发量应为:246.92*3=740
所以,最终算出来,其实并发用户数也不是很高,一般的系统,感觉jmeter里的并发线程数控制在500内就够了,再不行的话,1000内都足够了。如果超出1000了,看看是不是考虑用多个jmeter实例进行分布式压测,因为一般像大公司那种比较大的业务,压测都是分布式压测,压测机集群都好几十台起步。
当然,如果非要拼命在单个jmeter实例(也就是一个java进程)提升线程数,可以看看下面这篇文章:
https://www.blazemeter.com/blog/jmeter-maximum-concurrent-users
看看是如何靠增加堆大小之类,来提升到10000个线程的,不过我反正是不建议,毕竟机器一般也才几核、几十核为主,开那么多线程会导致频繁的线程切换。
线程组中其他属性的设置#
以下图为例:
300个线程,但是Ramp-up period 是300s,意思是在300s内将我那300个线程启动起来,也就是1s增加1个;如果你设为1的话,300个线程就会在1s内启动,我感觉对电脑冲击比较大,还是平缓一点好。
Loop count我这里是设置为无限,那,难道整个脚本就一直跑吗,当然不是,可以看到,我上图设置了Duration为600s,也就是说,脚本总共跑10分钟。
可以预测的是:
在前300s,会逐步从1个线程增加到300个线程;在后面300s,就是300个线程同时去跑脚本,这时候的压力是稳定的300 virtual user或者说300线程产生的并发。
jmeter运行#
严格压测时,我们一般不在GUI里面去运行,而是采用cli方式。
比如,在windows下用cli方式压测:
CopyF:\apache-jmeter-5.2.1\bin>jmeter -n -t Test.jmx -l result.jtl -j test.log
或者在linux下压测:
Copy./jmeter -n -t Test.jmx -l result.jtl
长时间压测
nohup ./jmeter -n -t Test.jmx -l result.jtl 2>&1 &
压测时,会产生这样的输出:
Copysummary = 3801 in 00:00:40 = 94.5/s Avg: 417 Min: 13 Max: 3817 Err: 0 (0.00%)
表示现在是压测开始后的第40s,3801是总共发出去的请求,94.5/s是这期间的tps,后面就是平均数、最小、最大、错误数
过一阵后,会连着出现这样的:
Copysummary + 2590 in 00:00:35 = 74.3/s Avg: 1076 Min: 97 Max: 9799 Err: 0 (0.00%) Active: 151 Started: 151 Finished: 0
summary = 6391 in 00:01:15 = 85.1/s Avg: 684 Min: 13 Max: 9799 Err: 0 (0.00%)
为+的那一行,表示的是增量,从上一行结束后,过去了35s,这35s期间产生了2590个请求,这期间的tps是74.3
为=的那一行,就是从脚本开始到目前为止,总的指标,如6391这个请求数,就是40s时候的请求数3801 + 增量的2590.
顺便给大家看下,我这次上线前,为了测试下稳定性,压了18个小时:
另外,后面的Active那些就是活跃线程数,我是用200并发压了18小时,第二天去,发现系统还是挺稳定。
相关推荐
- 电脑给另一个硬盘装系统(电脑给另一块硬盘装系统)
-
回答如下:以下是在Windows操作系统下的步骤:1.确保你有一个可用的Windows安装光盘或USB安装介质。2.将另一个硬盘连接到计算机上并确保电脑识别到它。3.打开计算机BIOS并确保在启...
- 设计师专用笔记本电脑排行榜
-
惠普战99采用了英特尔第十二代酷睿i7-12700H标压处理器和英伟达T600工作站级专业显卡的配置。存储方面支持双通道3200MHz内存和双M.2接口SSD,配置十分豪华。15.6英寸高色域高清IP...
-
- 打印机故障排查(打印机故障排查提示不接收任务怎么处理)
-
步骤/方式1点击电脑桌面左下角的开始按钮,选择设备和打印机的选项。步骤/方式2找到有故障的打印机,鼠标右键点击选择属性的选项。步骤/方式3在打印机属性页面,我们点击维护的选项。步骤/方式4在维护页面,选择对应的故障进行维护,即可解决故障亮灯...
-
2026-01-09 19:55 liuian
- 内部版本7601激活(内部版本7601影响使用吗)
-
激活方法如下右击计算机--属性,拉倒最下面,会提示该系统未激活,然后点击激活,输入密钥就可以了,需要连接互联网。如果没有互联网,也可以电话激活。下载安装内部专用激活工具激活就可以了Windows7内部...
- microsoft打不开怎么办(microsoftoffice打不开)
-
方法一:1、按Win+S组合键,或点击底部任务栏开始旁的搜索图标,在打开的Windows搜索窗口,搜索框输入服务,然后点击打开系统给出的最佳匹配服务应用;2、服务窗口,找到并双击打开WLA...
- 安卓仿苹果ios主题下载免费(安卓仿苹果ios12主题下载)
-
要把华为手机的主题改成类似iOS的风格,可以按照以下步骤进行操作:1.在华为应用商店中搜索并下载一个适合的iOS主题,例如iOSLauncher等。2.安装完成后,打开该主题应用,在设置中选择启...
- 声卡驱动安装哪个比较好(声卡驱动应该安装在哪里)
-
EXPSoundboard软件使用电脑自带的集成声卡就可以了。只是需要安装一些变声软件。如EXPSoundboard软件,使用这款EXPSoundboard中文版可以让你自由自在的在任何游戏中挂...
- 宽带登录网站(宽带登录网站怎么登录)
-
在浏览器内输入www.10010.com,进入中国联通网上营业厅后,选择“登录”,输入宽带账号与宽带密码,点击登录即可使用联通宽带登录联通网上营业厅。可通过以下方式办理联通宽带预约服务:1、登录联通网...
- tenda官网登入(tenda官网192.168.0.1登录)
-
腾达无线的路由器登录入口是:tplogin.cn电信运营商定制款登录地址是:192.168.2.1或者192.168.8.12、华为(容易)路由器华为路由器跟荣耀路由器只有IP地址,没有域名,它是...
- u盘格式化不了怎么回事(u盘格式化不了为什么)
-
第一种情况:u盘本身带有写保护开关的情况。这种情况一般是因为有些朋友借的U盘或者不了解U盘本身的情况,不注意打开了写保护开关,导致的U盘写保护,这种情况的解决方法就很简单了,找到开关关掉写保护即可。第...
- windows7专业版sp1补丁(win7旗舰版sp1补丁)
-
win7sp1补丁安装方法如下:1成后,需要打sp1补丁,不过微软对win7的支持已经结束了,建议升级新系统2到微软官网/zh-cn/download找到win7系统版本的补丁,点击下载3勾选对应系统...
- 无线ap面板哪个品牌好(无线ap面板什么品牌好)
-
作为工程商的我,用过用多牌子做无线覆盖工程,用过大品牌的有华为,H3C,思科,比较贵,性能强大。确实是不错的,就是费用高,老板指定就会用的。用过有中高端牌子有很多,但后面用着用着出现问题,不敢用了。现...
-
- 怎么下载07版的office(下载office2007的步骤)
-
office是每个电脑都必备的一个软件,那office2007免费完整版怎么下载呢?下面就来教教大家具体步骤。1、我们在浏览器输入栏搜索“zol”,然后选择官网进入。2、在页面右上角选择“软件下载”,然后选择“软件分类”,点击“办公软件”。...
-
2026-01-09 14:55 liuian
-
- 拼音五笔两用的输入法叫什么
-
这个是因为你电脑设置了五笔为默认输入法,所以你打开的任何窗口都是五笔输入法。你可以在电脑语言设置里面更改默认设置,如win10系统直接在输入法那里打开语言首选项,选择键盘那个选项直接可以按照自己的使用习惯更改默认输入法。可以在不同的窗口设置...
-
2026-01-09 14:05 liuian
-
- 外置sd卡文件加密软件(sd卡加密怎么破解)
-
不管是给手机sd卡加密还是外置sd卡加密,办法都是一样的,具体操作为以下几步:1、在手机【设置】中找到【安全】功能,不同的手机有不一样的选项,有的在【高级设置】中,而有的则在【设置】中。2、在【安全】选项中,找到【设置SD卡密码】或【加密外...
-
2026-01-09 13:55 liuian
- 一周热门
-
-
飞牛OS入门安装遇到问题,如何解决?
-
如何在 iPhone 和 Android 上恢复已删除的抖音消息
-
Boost高性能并发无锁队列指南:boost::lockfree::queue
-
大模型手册: 保姆级用CherryStudio知识库
-
用什么工具在Win中查看8G大的log文件?
-
如何在 Windows 10 或 11 上通过命令行安装 Node.js 和 NPM
-
威联通NAS安装阿里云盘WebDAV服务并添加到Infuse
-
Trae IDE 如何与 GitHub 无缝对接?
-
idea插件之maven search(工欲善其事,必先利其器)
-
如何修改图片拍摄日期?快速修改图片拍摄日期的6种方法
-
- 最近发表
- 标签列表
-
- python判断字典是否为空 (50)
- crontab每周一执行 (48)
- aes和des区别 (43)
- bash脚本和shell脚本的区别 (35)
- canvas库 (33)
- dataframe筛选满足条件的行 (35)
- gitlab日志 (33)
- lua xpcall (36)
- blob转json (33)
- python判断是否在列表中 (34)
- python html转pdf (36)
- 安装指定版本npm (37)
- idea搜索jar包内容 (33)
- css鼠标悬停出现隐藏的文字 (34)
- linux nacos启动命令 (33)
- gitlab 日志 (36)
- adb pull (37)
- python判断元素在不在列表里 (34)
- python 字典删除元素 (34)
- vscode切换git分支 (35)
- python bytes转16进制 (35)
- grep前后几行 (34)
- hashmap转list (35)
- c++ 字符串查找 (35)
- mysql刷新权限 (34)
