如何在容器中使用jmeter做压测

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了如何在容器中使用jmeter做压测相关的知识,希望对你有一定的参考价值。

参考技术A 为什么会有这样的需求,我也不知道,没有需求就创造需求呗,直接开整:

首先上docker.hub上看看有没有现成的,关键字 alpine/jmeter ,一搜索果然有:

entrypoint.sh内容看不到,前面PATH已经配置好,应该是直接执行的jmeter程序。先执行下试试:

在服务器/tmp目录上先放上预先准备好的测试计划文件(可以从jmeter的桌面ui版配置好后导出),-t参数指向这个计划文件,就可以运行起来了:

很方便很直接,如果要生成测试报告,也可以在命令后面带上 -l /tmp/result.jtl 或者是同时生成html页面报告文件 -l /tmp/result.jtl -e -o /tmp/jmeter ,然后用nginx
指向上这个 tmp/jmeter ,就可以页面查看执行报告了:

那有没有办法让容器一直启动着,随时需要压测随时上来敲命令就好? (不要问为什么要这样做,就是玩儿)

那就搞一个空运行的容器玩儿吧:

百度告诉我,这事儿要成,关键命令是 tail -f /dev/null ,有点意思,那就写DockerFile吧:

可以看到做的事情不多,加载5.4.3的jmeter安装包,解压、配置,顺便装个curl测试用。
配置完就 docker build -t jmeter:1.0 . 跑起来吧。

build完后,输入 docker run -it --name jmeter -v /tmp/:/tmp/ jmeter:1.0 /bin/sh 运行起来:

直接输入jmeter命令,可以看到是可用的,然后按照之前的命令去执行指定测试计划就可以了。

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

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

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

不同并发如何做压测?

如果手动逐步加压,不仅需要人肉改并发数,还需要花大量时间等待完成,可以用一个字概括:烦!所以,制定好策略,让程序自动加压,自动等待;完成后看压测监控记录,或者坐收报告是最完美的解决方案。

无UI执行JMeter

 jmeter -n -t <testplan filename> -l <listener filename>  

示例: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 jmeter -n -t $jmx_filename -l $jtl_filename &
  • nohup是no hang up 的缩写,就是不挂断的意思。如果你正在运行一个进程,而且你觉得在退出帐户时该进程还不会结束,那么可以使用nohup命令。该命令可以在你退出帐户/关闭终端之后继续运行相应的进程。在缺省情况下该作业的所有输出都被重定向到一个名为nohup.out的文件中。

  • & 指在后台运行注意了nohup没有后台运行的意思;&才是后台运行,那么,我们可以巧妙的把他们结合起来用就是nohup COMMAND &,这样就能使命令永久的在后台执行。

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

用项目实战来演示

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

github项目地址:https://github.com/princeqjzh/iJmeter/blob/master/automation/auto_stress_test.sh

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

export jmx_template="PreClassMenu_auto"  
export suffix=".jmx"  
export jmx_template_filename="$jmx_template$suffix"  
export os_type=`uname`  

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

我们接着往下看:

#!/usr/bin/env bash  
export jmx_template="PreClassMenu_auto"  
export suffix=".jmx"  
export jmx_template_filename="$jmx_template$suffix"  
export os_type=`uname`  
  
# 需要在系统变量中定义jmeter根目录的位置,如下  
# export jmeter_path="/your jmeter path/"  
  
# 清空nohup.out  
cat /dev/null > nohup.out  
  
# 强制杀掉JMeter进程  
killJMeter()  
  
    pid=`ps -ef|grep jmeter|grep java|awk \'print $2\'`  
    echo "jmeter Id list :$pid"  
    if [[ "$pid" = "" ]]  
    then  
      echo "no jmeter pid alive"  
    else  
      kill -9 $pid  
    fi  
  

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

#!/usr/bin/env bash  
export jmx_template="PreClassMenu_auto"  
export suffix=".jmx"  
export jmx_template_filename="$jmx_template$suffix"  
export os_type=`uname`  
  
# 需要在系统变量中定义jmeter根目录的位置,如下  
# export jmeter_path="/your jmeter path/"  
  
# 清空nohup.out  
cat /dev/null > nohup.out  
  
# 强制杀掉JMeter进程  
killJMeter()  
  
    pid=`ps -ef|grep jmeter|grep java|awk \'print $2\'`  
    echo "jmeter Id list :$pid"  
    if [[ "$pid" = "" ]]  
    then  
      echo "no jmeter pid alive"  
    else  
      kill -9 $pid  
    fi  
  
  
thread_number_array=(10 20 30 40 50)  

这里定义了一个数组thread_number_array,这个数组大家猜一猜是什么意思。是并发数,代码期望有五个并发数,分别为:10,20,30,40,50。下一步至关重要,请集中注意!

#!/usr/bin/env bash  
export jmx_template="PreClassMenu_auto"  
export suffix=".jmx"  
export jmx_template_filename="$jmx_template$suffix"  
export os_type=`uname`  
  
# 需要在系统变量中定义jmeter根目录的位置,如下  
# export jmeter_path="/your jmeter path/"  
  
# 清空nohup.out  
cat /dev/null > nohup.out  
  
# 强制杀掉JMeter进程  
killJMeter()  
  
    pid=`ps -ef|grep jmeter|grep java|awk \'print $2\'`  
    echo "jmeter Id list :$pid"  
    if [[ "$pid" = "" ]]  
    then  
      echo "no jmeter pid alive"  
    else  
      kill -9 $pid  
    fi  
  
  
thread_number_array=(10 20 30 40 50)  
for num in "$thread_number_array[@]"  
do  
    # 生成对应压测线程的jmx文件  
    export jmx_filename="$jmx_template_$num$suffix"  
    export jtl_filename="test_$num.jtl"  
  
    rm -f $jmx_filename $jtl_filename  
    cp $jmx_template_filename $jmx_filename  
    echo "生成jmx压测脚本 $jmx_filename"  
  
    if [[ "$os_type" == "Darwin" ]]; then  
        sed -i "" "s/thread_num/$num/g" $jmx_filename  
    else  
        sed -i "s/thread_num/$num/g" $jmx_filename  
    fi  
  
    # JMeter 静默压测  


nohup $jmeter_path/bin/jmeter -n -t $jmx_filename -l

          $jtl_filename &

sleep 65  
    killJMeter  
    rm -f $jmx_filename  
done  
echo "自动化压测全部结束"  

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

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

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

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

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

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

  • sed:这是我们的重头戏,用来正则替换,我们用变量num来替换临时文件中的thread_num,它是什么?请看下面的截图:

哇!把并发数用thread_num替换了,之所以这么做是为了让正则更方便的找到它,试想一下,如果我使用数字1或者数字11,正则会很难定位到它。用正则将num替换上去,也就实现了用命令修改临时文件的并发数,多么伟大的操作!

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

  • sleep和killJMeter:这两个命令组合起来的意思是:65秒后杀掉压测进程,因为有时候JMeter并不能正常退出!KillJMeter是最开始时定义的函数,它通过grep和awk筛选出进程并杀掉,不过多讲解了。

最后用sh命令执行shell脚本,会得到下面的结果:

写在最后

本文使用漫画形式向大家展示了jmeter的进阶用法:如何自动化运行jmeter。同学们,不知道你们学会了吗?请同学们勤加练习,争取学到更多的知识。
本内容出自 霍格沃兹测试学院 ,接下来会有什么哪些即有趣又有内容的文章呢?请继续关注我们。

- 今日互动 - ****

小编PS:教师节的中奖名单在次条哦!非常感谢小伙伴的参与。中奖结果是谁?只有点开才知道。保证很惊喜。霍格沃兹测试学院对于刷赞、小号零容忍。

—霍格沃兹测试学院


往期推荐

**大话JMeter3|如何借助工具搞定高颜值的性能监控报告
**

大话JMeter2|正确get参数传递和HTTP如何正确使用

大话jmeter,带你了解jmeter的基础用法

测试工程师的转型探索:如何让产品质量变得更好?

**
**

**欢迎文章下方留言并分享给其他测试小伙伴哦~
**

(如有问题请私聊jasmine小助手)

来霍格沃兹测试开发学社,学习更多软件测试与测试开发的进阶技术,知识点涵盖web自动化测试 app自动化测试、接口自动化测试、测试框架、性能测试、安全测试、持续集成/持续交付/DevOps,测试左移、测试右移、精准测试、测试平台开发、测试管理等内容,课程技术涵盖bash、pytest、junit、selenium、appium、postman、requests、httprunner、jmeter、jenkins、docker、k8s、elk、sonarqube、jacoco、jvm-sandbox等相关技术,全面提升测试开发工程师的技术实力
QQ交流群:484590337
公众号 TestingStudio
点击获取更多信息

以上是关于如何在容器中使用jmeter做压测的主要内容,如果未能解决你的问题,请参考以下文章

如何做压测?

还在看美女直播跳舞,过时啦老夫反手就是一波用jmeter对直播间做压测

Jmeter压测

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

jmeter中测试接口

使用Jmeter如何测试下载接口