大话JMeter4|不同的并发数可以自动化做压测吗?

本文涉及的产品
性能测试 PTS,5000VUM额度
简介: 大话JMeter4|不同的并发数可以自动化做压测吗?

上节课爱画漫画的小哥哥用漫画形式向大家展示了JMeter的进阶用法:如何搭建InfluxDB,使用更炫酷的Grafana。

看到很多小伙伴觉得看的不过瘾,在强烈的催促下,小哥哥的新文章又出来了。这次小哥哥又给我们带来怎样的惊喜呢?接着看下去吧!

如果手动逐步加压,不仅需要人肉改并发数,还需要花大量时间等待完成,可以用一个字概括:

完成后看压测监控记录,或者坐收报告是最完美的解决方案。

示例:

jmeter -n -t testplan.jmx -l test.jtl

示例含义:

则表示以命令行模式运行testplan.jmx文件,输出的日志文件为test.jtl

具体的参数信息如下:

-h 帮助 → 打印出有用的信息并退出

-n 非 GUI 模式 → 在非 GUI 模式下运行 JMeter

-t 测试文件 → 要运行的 JMeter 测试脚本文件

-l 日志文件 → 记录结果的文件

-r 远程执行 → 在Jmter.properties文件中指定的所有远程服务器

-H 代理主机 → 设置 JMeter 使用的代理主机

-P 代理端口 → 设置 JMeter 使用的代理主机的端口号

我们设置并录制好脚本,此时可以选择保存。然后我们就得到了一份jmx文件,于是,就可以用上面的命令加载这个文件实现无UI运行啦!

在shell命令中,我们使用nohup来运行jmeter:

  • nohup是no hang up 的缩写,就是不挂断的意思。
    如果你正在运行一个进程,而且你觉得在退出帐户时该进程还不会结束,那么可以使用nohup命令。
    在缺省情况下该作业的所有输出都被重定向到一个名为nohup.out的文件中。
  • & 指在后台运行
    &才是后台运行,那么,我们可以巧妙的把他们结合起来用就是nohup COMMAND &,这样就能使命令永久的在后台执行。

是的,小兔说的没错,就像下面的图片一样,我们在jmeter的UI界面中配置的参数信息全在jmx文件中,比如并发数为:

11

要解释一段代码着实不容易,这里请允许用文字来表述。下面是shell代码,将会挑重点来解释,如果对语法生疏,可以自行网上搜索。

github项目地址:

https://github.com/princeqjzh/iJmeter/blob/master/automation/auto_stress_test.sh 1

运行代码前需要将jmeter目录设置为环境变量,shell才可以知道所运行的jmeter在哪个位置。

首先,用export定义几个变量,这些变量后面会用到,其中jmx_template_filename变量存放的是jmx的临时名子,实际工作中要设置多个并发数,比如10,20,30,40,每一个并发数都要有一个文件与之对应,称之为临时文件,这四个jmx文件的并发数分别为:

10,20,30,40。

我们接着往下看:

遇到了cat命令和killJMeter函数,后面再来讲这两部分,继续往下看。

是并发数,代码期望有五个并发数,分别为:

10,20,30,40,50。下一步至关重要,请集中注意!

这就是全部代码,你可以参考下面的解释:

我们对thread_number_array数组依次遍历,do和done之间的内容就是每次遍历要执行的操作。

这是两个变量,jmx_filename就是临时jmx文件的名子,${}代表变量,比如${jmx_template}指我们要用jmx_template这个变量,变量名类似PreClassMenu_auto_10.jmx,PreClassMenu_auto_20.jmx,PreClassMenu_auto_30.jmx等等。

用于清除闲杂文件,如果有当前目录文件与jmx_filename和jtl_filename重名,就删除它。

是复制命令,将模板中的内容复制到临时文件中,也可以理解为利用模板建立临时文件。

用来判断是不是mac电脑,mac电脑上输入uname就能显示Darwin,如果不显示则为linux,之所以要判断,是因为后面的sed命令在mac与linux上稍微有点不同。

这是我们的重头戏,用来正则替换,我们用变量num来替换临时文件中的thread_num,它是什么?

请看下面的截图:

哇!把并发数用thread_num替换了,之所以这么做是为了让正则更方便的找到它,试想一下,如果我使用数字1或者数字11,正则会很难定位到它。

用正则将num替换上去,也就实现了用命令修改临时文件的并发数,多么伟大的操作!

这个命令前面介绍过,就不多说了,它无UI运行jmeter,在缺省情况下该作业的所有输出都被重定向到一个名为nohup.out的文件中,代码最开始的cat是为了清空nohup.out文件。换句话说,每次运行shell脚本,都会清空nohup.out记录文件,相当于清空日志。

65秒后杀掉压测进程,因为有时候JMeter并不能正常退出!

KillJMeter是最开始时定义的函数,它通过grep和awk筛选出进程并杀掉,不过多讲解了。


喜欢软件测试的小伙伴们,如果我的博客对你有帮助、如果你喜欢我的博客内容,请 “点赞” “评论” “收藏” 一键三连哦!


相关实践学习
通过性能测试PTS对云服务器ECS进行规格选择与性能压测
本文为您介绍如何利用性能测试PTS对云服务器ECS进行规格选择与性能压测。
相关文章
|
6月前
|
Ubuntu Java 测试技术
【Linux】一站式教会:Ubuntu(无UI界面)使用apache-jmeter进行压测
【Linux】一站式教会:Ubuntu(无UI界面)使用apache-jmeter进行压测
212 1
|
消息中间件 弹性计算 Java
使用阿里云性能测试工具 JMeter 场景压测 RocketMQ 最佳实践
使用阿里云性能测试工具 JMeter 场景压测 RocketMQ 最佳实践
1253 6
|
2月前
|
缓存 Java 测试技术
谷粒商城笔记+踩坑(11)——性能压测和调优,JMeter压力测试+jvisualvm监控性能+资源动静分离+修改堆内存
使用JMeter对项目各个接口进行压力测试,并对前端进行动静分离优化,优化三级分类查询接口的性能
谷粒商城笔记+踩坑(11)——性能压测和调优,JMeter压力测试+jvisualvm监控性能+资源动静分离+修改堆内存
|
6月前
|
消息中间件 Java 测试技术
性能工具之Jmeter扩展函数及压测ActiveMQ实践
【5月更文挑战第18天】性能工具之Jmeter扩展函数及压测ActiveMQ实践
105 5
|
3月前
|
存储 监控 数据可视化
性能监控之JMeter分布式压测轻量日志解决方案
【8月更文挑战第11天】性能监控之JMeter分布式压测轻量日志解决方案
89 0
性能监控之JMeter分布式压测轻量日志解决方案
|
6月前
|
监控 供应链 测试技术
PTS压测问题之自动变成500 并发如何解决
PTS(Performance Testing Service)是一项面向网站、应用等提供的压力测试服务,用于模拟不同场景下的用户访问,评估系统的性能表现;在进行PTS压测时,可能会出现一些异常或报错,本合集将PTS压测中频繁出现的问题及其解决办法进行汇编,旨在帮助用户更有效地进行性能测试和问题定位。
397 2
|
6月前
|
测试技术 UED
PTS压测问题之资源准备好慢如何解决
PTS(Performance Testing Service)是一项面向网站、应用等提供的压力测试服务,用于模拟不同场景下的用户访问,评估系统的性能表现;在进行PTS压测时,可能会出现一些异常或报错,本合集将PTS压测中频繁出现的问题及其解决办法进行汇编,旨在帮助用户更有效地进行性能测试和问题定位。
280 1
|
4月前
|
测试技术 Linux
linux 服务器运行jmeter 进行服务性能压测
linux 服务器运行jmeter 进行服务性能压测
338 0
|
6月前
|
监控 数据可视化 测试技术
性能工具之JMeter+InfluxDB+Grafana打造压测可视化实时监控
【5月更文挑战第23天】性能工具之JMeter+InfluxDB+Grafana打造压测可视化实时监控
569 6
性能工具之JMeter+InfluxDB+Grafana打造压测可视化实时监控
|
6月前
|
Web App开发 Java 测试技术
秒懂HTTPS接口(JMeter压测篇)
【5月更文挑战第11天】秒懂HTTPS接口(JMeter压测篇)
1692 2
秒懂HTTPS接口(JMeter压测篇)