大话JMeter4|不一样的并发数能够自动化作压测吗?


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


看到不少小伙伴以为看的不过瘾,在强烈的催促下,小哥哥的新文章又出来了。此次小哥哥又给咱们带来怎样的惊喜呢?接着看下去吧!linux


不一样并发如何作压测?git



若是手动逐步加压,不只须要人肉改并发数,还须要花大量时间等待完成,能够用一个字归纳:烦!因此,制定好策略,让程序自动加压,自动等待;完成后看压测监控记录,或者坐收报告是最完美的解决方案。

无UI执行JMetergithub




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



要解释一段代码着实不容易,这里请容许用文字来表述。下面是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脚本,会获得下面的结果:






写在最后bash



本文使用漫画形式向你们展现了jmeter的进阶用法:如何自动化运行jmeter。同窗们,不知道大家学会了吗?请同窗们勤加练习,争取学到更多的知识。

本内容出自 霍格沃兹测试学院,接下来会有什么哪些即有趣又有内容的文章呢?请继续关注咱们。
相关文章
相关标签/搜索