「转」基于Jmeter和Jenkins搭建性能测试框架
搭建这个性能测试框架是希望能够让每个人(开发人员、测试人员)都能快速的进行性能测试,而不需要关注性能测试环境搭建过程。因为,往往配置一个性能环境可能需要很长的时间。
1、性能测试流程
该性能测试框架工作的流程主要有:触发测试–>部署测试脚本–>部署被测系统–>Jmeter打压–>被测系统日志分析,5个阶段。
体现在Jenkins上,就是下面这个jenkins 的MultiJob Project——Performance-test-jobs:
注意:在选择Performance-test-jobs的构建步骤时,要选择Conditional steps(multiple)。
下面对该性能测试框架搭建的过程进行详细的介绍。
2、环境需求
整个测试框架需要以下机器:
1)jenkins master:用于管理测试机、建立性能测试job、启动性能测试、展示性能测试结果。
2)Load generator:用来给被测试服务器发送请求,当一台Load generator发送的并发请求数达不到测试要求时,可能需要配置多台。Setup ENV阶段的Performance-test-script-deployment以及Run test阶段的job都是运行在这机器上的。
3)被测试服务器:用于安装被测试服务的机器,分析被测试服务的log的job也是运行在这个机器上的。
其中,Load generator和被测试服务器都是作为slave节点挂载在jenkins master上的。
3、安装必要软件
3.1、安装Jenkins及插件
安装Jenkins的步骤,这里不展开讲了。这里主要介绍一下与性能测试有关的jenkins插件——Performance Plugin。这个插件的作用是解析Jmeter生成的测试报告,直观的展示出来。
安装插件的方法很简单,登陆Jenkins,在Manage Plugins界面搜索“Performance Plugin”点击安装即可。
如果安装正确,在性能测试job的配置页面的 “Add post-build action” 步骤里面能够看到 “Publish Performance Test Result Report” 选项。
3.2、Jmeter安装及配置
在性能测试压力机上,下载并安装Jmeter(下载地址:http://jmeter.apache.org/download_jmeter.cgi),解压到目录/usr/local。[下载二进制的]
之后,下载jmeter-plugins插件JMeterPlugins-Standard-1.2.0.zip(下载地址http://jmeter-plugins.org/downloads/all/)。
解压后将其中的jar包拷贝至jmeter安装目录/lib/ext/目录(如果没有则创建之)下即可。
这个插件的作用是,当通过no-GUI方式执行测试之后,将生成的测试结果文件*.jtl解析成图片的形式,比较直观。
3.3、安装系统资源监控插件
为了监控被测服务器的系统资源,需要在被测试机上安装ServerAgent,下载ServerAgent-2.2.1.zip(下载地址http://jmeter-plugins.org/downloads/all/),并在被测试机上启动startAgent.sh。该插件能够对服务器的 CPU、内存、Swap、磁盘 I/O、网络 I/O 进行监控!
4、Jmeter GUI上制定测试计划
我们的测试执行实在Jenkins中通过非GUI方式执行Jmeter压力测试的。在JmeterGUI上制定测试计划的目的是,将测试计划保存成.jmx文件,以便能够在Jmeter的非GUI模式下执行测试。
4.1、建立Thread Group
有三个必须设置的属性(见下图红框部分),这里采用函数__P()设置属性名和默认值的形式设置这三个属性,以方便在使用no-GUI模式启动Jmeter进行测试时,使用–jmeterproperty选项对属性值进行赋值。
4.2、添加HTTP Request
由于我们的测试是发送HTTP请求给Serving服务器,因此这里选择添加的Sampler是HTTP Request。
这里需要添加被测服务器的域名或者网址,这里也采用函数__P()设置属性名和默认值的形式设置这个属性。
另外,还要设置请求的具体地址Path。由于我们测试过程中请求的网址是不一样的。因此需要需要对这个Path进行参数化,指定为变量${path}。又由于我们请求的网址是存放到一个叫作path.log的文件中的。因此,参数化的方法适宜采用CSV Data Set Config。这里Filename我们设置为属性UrlFile,该属性可以在使用no-GUI模式启动Jmeter进行测试时,使用–jmeterproperty选项指定具体的文件。
4.3、添加Listener
在TestPlan上右击,Add–>Listener–>Aggregate Report。
另外,添加了PerfMon Metrics Collector的Listner,来收集被测试机的CPU,memory信息。
可以指定将report保存到某个文件,如上图中所示保存到jtl文件,在非GUI模式下运行Jmeter这是非常必要的。
4.4、生成测试计划jmx文件
一切设置妥当之后,点击菜单栏上的File->Save Test Plan As.
此步骤可以将该Test Plan保存为.jmx格式的文件。该文件用来进行non-GUI方式进行Jmeter测试。
5、non-GUI方式执行Jmeter
non-GUI方式执行Jmeter的命令:
|
1
2
3
4
5
6
7
|
jmeter.sh -n -t test.jmx -l result.jtl \--jmeterproperty threadCount=${CONCURRENCY} \--jmeterproperty LoopCount=${LOOPCOUNT} \--jmeterproperty adclient=${SERVER} \--jmeterproperty UrlFile=path.log \--jmeterproperty RampUp=${RAMPUP} \--jmeterproperty throughput=${THROUGHPUT} |
说明:
-n 非 GUI 模式 -> 在非 GUI 模式下运行 JMeter
-t 测试文件 -> 要运行的 JMeter 测试脚本文件
-l 日志文件 -> 记录结果的文件
–jmeterproperty设置test.jmx中的属性(见“Jmeter GUI上制定测试计划”部分)
6、生成报告图表
我们可以通过Jenkins上安装的JMeterPlugins-Standard插件来将测试结果文件.jtl格式的文件解析成图表。
|
1
2
3
4
5
6
7
8
9
10
11
12
|
$JMETEREXT= /usr/local/apache-jmeter-2.13/lib/extjava -jar $JMETEREXT/CMDRunner.jar --tool Reporter \--generate-png ResponseTimesOverTime.png --input-jtl result.jtl --plugin-type ResponseTimesOverTimejava -jar $JMETEREXT/CMDRunner.jar --tool Reporter \--generate-png CPU.png --input-jtl cpu.jtl --plugin-type PerfMonjava -jar $JMETEREXT/CMDRunner.jar --tool Reporter \--generate-png MEM.png --input-jtl mem.jtl --plugin-type PerfMonjava -jar $JMETEREXT/CMDRunner.jar --tool Reporter \--generate-png TransactionsPerSecond.png --input-jtl trans.jtl --plugin-type TransactionsPerSecond |
7、job shell设置
Jenkins的job中通过参数传递给jmeterproperty中的变量中。
Execute shell的内容:
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
|
source /etc/profileTHROUGHPUT=`expr 60 \* ${QPS}`RUNFOLDER=/usr/local/jmeter-demo/src/test/jmeterJMETERBIN=/usr/local/apache-jmeter-2.13/binJMETEREXT=/usr/local/apache-jmeter-2.13/lib/extRESULTJTL=$RUNFOLDER/result.jtlCPUJTL=$RUNFOLDER/cpu.jtlMEMJTL=$RUNFOLDER/mem.jtlTRANSJTL=$RUNFOLDER/trans.jtlrm -f $RUNFOLDER/path.logrm -f $RUNFOLDER/*.jtlrm -f $RUNFOLDER/*.pngrm -f $WORKSPACE/*.pngrm -f $WORKSPACE/*.jtlcd /usr/local/jmeter-demo/src/test/jmeter && python appending.py ${APPENDING}cd /usr/local/jmeter-demo/src/test/jmeter && $JMETERBIN/jmeter.sh -n -t test.jmx -l result.jtl \--jmeterproperty threadCount=${CONCURRENCY} \--jmeterproperty LoopCount=${LOOPCOUNT} \--jmeterproperty adclient=${SERVER} \--jmeterproperty UrlFile=path.log \--jmeterproperty RampUp=${RAMPUP} \--jmeterproperty throughput=${THROUGHPUT}java -jar $JMETEREXT/CMDRunner.jar --tool Reporter --generate-png ${RESULTJTL%.*}_ResponseTimesOverTime.png --input-jtl $RESULTJTL --plugin-type ResponseTimesOverTimejava -jar $JMETEREXT/CMDRunner.jar --tool Reporter --generate-png ${CPUJTL%.*}_CPU.png --input-jtl $CPUJTL --plugin-type PerfMonjava -jar $JMETEREXT/CMDRunner.jar --tool Reporter --generate-png ${MEMJTL%.*}_MEM.png --input-jtl $MEMJTL --plugin-type PerfMonjava -jar $JMETEREXT/CMDRunner.jar --tool Reporter --generate-png ${TRANSJTL%.*}_TransactionsPerSecond.png --input-jtl $TRANSJTL --plugin-type TransactionsPerSecondcp /usr/local/jmeter-demo/src/test/jmeter/*.png $WORKSPACEcp /usr/local/jmeter-demo/src/test/jmeter/result.jtl $WORKSPACE |
「转」基于Jmeter和Jenkins搭建性能测试框架的更多相关文章
- 基于Jmeter和Jenkins搭建性能测试框架
搭建这个性能测试框架是希望能够让每个人(开发人员.测试人员)都能快速的进行性能测试,而不需要关注性能测试环境搭建过程.因为,往往配置一个性能环境可能需要很长的时间. 1.性能测试流程 该性能测试框架工 ...
- Jmeter+ant+Jenkins接口自动化框架搭建
摘自:https://testerhome.com/topics/13389 一.背景 上一篇讲了Jmeter 接口自动化-脚本数据分离实例,我们知道怎么利用Jmeter去编写接口自动化脚本,但是接 ...
- jmeter+ant+jenkins搭建接口自动化测试环境
jmeter+ant+jenkins搭建接口自动化测试环境(基于win) 1.jmeter jmeter依赖java运行环境,所以需要提前下载jdk并配置好环境变量 官网下载(http://jmete ...
- 基于Jmeter+maven+Jenkins构建性能自动化测试平台
一.目的: 为能够将相关系统性能测试做为常规化测试任务执行,且可自动无人值守定时执行并输出性能测试结果报告及统计数据,因此基于Jmeter+maven+Jenkins构建了一套性能自动化测试平台 ...
- 基于Jmeter跟Jenkins的自动化性能测试的一站式解决方案(转)
www.MyException.Cn 网友分享于:2015-08-26 浏览:0次 基于Jmeter和Jenkins的自动化性能测试的一站式解决方案 作者: Yu, Qingguo Shen, ...
- 「MoreThanJava」Day 1:环境搭建和程序基本结构元素
「MoreThanJava」 宣扬的是 「学习,不止 CODE」,本系列 Java 基础教程是自己在结合各方面的知识之后,对 Java 基础的一个总回顾,旨在 「帮助新朋友快速高质量的学习」. 当然 ...
- Jmeter+Ant+Jenkins搭建持续集成的接口测试(推荐 Mark)
转自:http://my.oschina.net/hellotest/blog/516079 目录[-] 一.Jmeter+ant 二.Jmeter+ant+Jenkins 三.Tomcat配置虚拟目 ...
- Jmeter+Ant+Jenkins搭建持续集成的接口测试框架
https://my.oschina.net/hellotest/blog/516079 摘要: 一个系统通常有多个接口,软件的生命周期中,我们会不断的去优化老的接口和开发新的接口,那么在这个过程中, ...
- 基于Jmeter和Testlink的自动化测试框架研究与实施
关于测试框架搭建的详细过程,会在另一篇文章中详细介绍:http://www.cnblogs.com/leeboke/p/6145977.html 摘 要 目前基于Jmeter的接口自动化测试框架,大多 ...
随机推荐
- EF to linq 左连接
如果连接的数据不存在用 null 表示,则可以左连接查询,但是如果数据类型为 int 则会出错. var ng = (from g in _db.NET_NEWS_GROUP join z in _d ...
- javasisst & JAVA8
今天在服务器上启动tomcat7的时候,提示如下异常: java.io.IOException: invalid constant type: 15 具体看是javasisst抛出来的. 系统运行环境 ...
- Bootstrap中的Affix插件
我们为什么要用bootstrap?因为懒!哦....不,是因为方便,呃...意思差不多. 今天来说说Affix这个插件,它可以使导航栏固定,免去了自己手写的麻烦,用着非常方便,废话不多说,下面是用法. ...
- 斜率dp+cdq分治
写在前面 这个东西应该是一个非常重要的套路......所以我觉得必须写点什么记录一下,免得自己忘掉了 一直以来我的斜率dp都掌握的不算很好......也很少主动地在比赛里想到 写这个的契机是noi.a ...
- BZOJ 题解continue
1041 圆上的整点 暴力枚举 会超时 这道题很像之前一次noip模拟题(当时的我还太水了(虽然现在也很水)) x2+y2=R2 考虑变型 x2=(R+y)(R-y) int d=gcd(R,y) i ...
- 深入探索 高效的Java异常处理框架
转载自:http://www.sunwei.org/archives/196 摘要:本文从Java异常最基本的概念.语法开始讲述了Java异常处理的基本知识,分析了Java异常体系结构,对比Sprin ...
- Android布局优化思考
一.关于RelativeLayout和LinearLayout的使用 由源码可以知道,RelativeLayout需要对其子View进行两次measure过程,而LinearLayout只需一次mea ...
- Java面向对象编程三大特性 --- 多态
多态特性: 子类Child继承父类Father,我们可以编写一个指向子类的父类类型引用,该引用既可以处理父类Father对象,也可以处理子类Child对象,当相同的消息发送给子类或者父类对象时,该对象 ...
- [bzoj3931][CQOI2015]网络吞吐量——最短路+网络流
题目 传送门 题解 第一次一遍就AC一道bzoj上的题,虽然是一道水题... 我们做一边最短路,求出每个点的dist,然后再做一次类似spfa的操作,求出每个点是否可以用于建图. 在新图上拆点跑一边d ...
- Django-models class Meta:元类
Django模型之Meta选项详解 Model 元数据就是 "不是一个字段的任何数据" -- 比如排序选项, admin 选项等等. Django模型类的Meta是一个内部类, ...