JMeter使用了不一样技术和协议,是一款能够进行配置和执行负载测试、性能测试和压力测试的工具。html
1.首先必须安装java环境,最新版本Apache JMeter 3.0 须要JRE 1.7或者更高版本java
2.从http://jmeter.apache.org/download_jmeter.cgi下载最新版本的JMeter,将它解压到例如D:\jmeter下(Windows),文件夹结构应该以下:mysql
1
2
3
4
5
6
7
8
|
D:.
└─jmeter
├─bin
├─docs
├─extras
├─lib
├─licenses
└─printable_docs
|
bin 目录下存放的是可执行的程序、配置文件和日志文件。web
jmeter.bat 是Jmeter的主运行程序,咱们经过这个程序来启动JMeter。这个文件能够被编辑,好比修改JVM参数:(注意 HEAP和PermSize之和不要超过物理内存的50%)sql
set HEAP=-Xms512m -Xmx512m数据库
set PERM=-XX:PermSize=128m -XX:MaxPermSize=128mapache
jmeter-server.bat 是JMeter联机负载测试的组件,若是须要作联机测试,须要在负载机器上启动该程序。json
lib 目录下包含ext、junit目录及各类jar包windows
docs 目录下存放的是API文档、默认的样式文件及UI图片等。api
3.而后你就能够进入到D:\jmeter\bin(对于Windows用户),执行jmeter.bat,能够看到JMeter GUI的启动界面:
本文使用聚合数据的老黄历接口为例,api接口文档:https://www.juhe.cn/docs/api/id/65
测试计划描述了执行测试过程当中JMeter的执行过程和步骤,一个完整的测试计划包括一个或者多个线程组(Thread Groups)、逻辑控制(Logic Controller)、实例产生控制器(Sample Generating Controllers)、侦听器(Listener)、定时器(Timer)、比较(Assertions)、配置元素(Config Elements)。
打开JMeter时,它已经创建一个默认的测试计划,一个JMeter应用的实例只能创建或者打开一个测试计划。这里,咱们假设须要JMeter模拟五个请求者(也就是五个线程),每一个请求者连续请求两次
这一步,咱们将向测试计划中增长相关负载设置,使Jmeter知道咱们须要模拟五个请求者,每一个请求者在测试过程当中连续请求两次。详细步骤以下:
1. 选中可视化界面中左边树的Test Plan节点,单击右键,选择Add->Threads(Users)->Thread Group,界面右边将会出现他的设置信息框。
2. Thread Group有三个和负载信息相关的参数:
Number of Threads: 设置发送请求的用户数目
Ramp-up period: 每一个请求发生的总时间间隔,单位是秒。好比你的请求数目是5,而这个参数是10,那么每一个请求之间的间隔就是10/5,也就是2秒
Loop Count: 请求发生的重复次数
根据咱们演示例子的设计,咱们应该将Number of Threads设置为5,Ramp-up period设置为0(也就是同时并发请求),不选中forever,在Loop Count后面的输入框中输入2
设置后的屏幕截图以下:
实际的测试工做每每是针对同一个服务器上Web应用展开的,因此Jmeter提供了这样一种设置, 在默认Http属性设置须要被测试服务器的相关属性,之后的http请求设置中就能够忽略这些相同参数的设置,减小设置参数录入的时间。
设置默认http属性步骤:
1. 选中可视化界面中左边树的Test Plan节点,单击右键,选择Add->Config Element->HTTP Request Defaults,界面右边将会出现他的设置信息框。
2.默认http属性的主要参数说明以下:
protocal: 发送测试请求时使用的协议
server name or ip:被测试服务器的ip地址或者名字
path: 默认的起始位置
port number: 服务器提供服务的端口号
设置后的屏幕截图以下:
如今咱们须要增长http请求了,他也是咱们测试的内容主体部分。你能够经过下面的步骤来增长性的http请求:
1. 选中可视化界面中左边树的Thread Group节点,单击右键,选择Add->Sampler->HTTP Request,界面右边将会出现他的设置信息框。
2. 增长的属性中有发送http时方法的选择,你能够选择为get或者post。
咱们如今增长两个http 请求,由于咱们设置了默认的http属性,因此和默认http属性中相同的属性再也不重复设置。根据接口文档,设置请求参数date和key(自行申请)
设置后的屏幕截图以下:
增长listener是为了记录测试信息而且可使用Jmeter提供的可视化界面查看测试结果,里面有好几种结果分析方式可供选择,你能够根据本身习惯的分析方式选择不一样的结果显示方式,咱们这里同时使用表格和树的形式来查看和分析测试结果。你能够经过下面的步骤来增长listener:
1. 选中可视化界面中左边树的Thread Group节点,单击右键,选择Add->Listener->View Results Tree,界面右边将会出现他的设置信息和结果显示框。
2. 选中可视化界面中左边树的Thread Group节点,单击右键,选择Add->Listener->View Results in Table,界面右边将会出现他的设置信息和结果显示框。
方式一:经过单击菜单栏run -> Start开始执行测试计划
方式二:在左边树的Thread Group节点,单击右键,选择Start 开始执行测试线程组
View Results in Table:
View Results Tree:
在使用Jemeter作压力测试的时候,每每须要参数化。这个时候咱们就可使用CSV Data Set Config来实现。
1.首先经过Test Plan或者Thread Group的Add->Config Element->CSV Data Set Config添加,本实例中将date参数化。
2.建立D:\date.txt,以下:
3.CSV Data Set Config各个参数的简要说明:
FileName: 即同目录下csv文件的名称
File Encoding: 默认为ANSI
Varible Names: 定义文本文件中的参数名,参数之间逗号分隔.定义后可在脚本在以Shell变量的一样的方式引用
Allow Quoated data: 双引号相关
Recycle on EOF: 设置为True后,容许循环取值
Stop Thread on EOF: 当Recycle on EOF为false而且Stop Thread on EOF为true,则读完csv文件中的记录后,中止运行
Sharing Mode: 设置是否线程共享
设置CVS参数,设置好屏幕截图以下
从新运行,检查View Results Tree 中的Request,可发现各个请求中的date已实现参数化
在这一节中,咱们建立50个用户,每次执行2条sql语句,重复执行100次。总请求数为 (50 Users)x(2 requests)x(repeat 100 times)=10,000 JDBC requests.
1.本实例使用 MySQL 数据库驱动。将数据库驱动(ex.mysql-connector-java-5.1.40-bin.jar)下载存放到 JMeter 安装目录下的./lib 目录中,如本教程安装目录D:\jmeter\lib
数据库驱动下载地址:http://dev.mysql.com/downloads/connector/j/
2.本实例使用MySQL数据库,MySQL数据库安装见教程:《MYSQL 免安装版(windows 7/64)》
本实例使用本地数据库test中的test表。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
|
SET
FOREIGN_KEY_CHECKS=0;
-- ----------------------------
-- Table structure for test
-- ----------------------------
DROP
TABLE
IF EXISTS `test`;
CREATE
TABLE
`test` (
`
name
`
varchar
(255)
DEFAULT
NULL
,
`age`
int
(11)
DEFAULT
NULL
,
`sex`
varchar
(255)
DEFAULT
NULL
) ENGINE=InnoDB
DEFAULT
CHARSET=utf8;
-- ----------------------------
-- Records of test
-- ----------------------------
INSERT
INTO
`test`
VALUES
(
'Cherish'
,
'29'
,
'F'
);
INSERT
INTO
`test`
VALUES
(
'Cherish'
,
'27'
,
'F'
);
INSERT
INTO
`test`
VALUES
(
'Milton'
,
'28'
,
'G'
);
INSERT
INTO
`test`
VALUES
(
'Milton'
,
'26'
,
'G'
);
|
使用JMeter建立任何测试计划,首先第一步是建立线程组。在线程组中能够设定模拟用户数、请求发送频率、总共发送请求数。
选中测试计划->右键->选择Add->Threads(Users)->Thread Group 配置后以下:
首先,配置JDBC链接信息,选中线程组 JDBC Users,右键,选择
Variable Name:myDatabase (这个配置,在后面requests请求中,要使用到,表示调用该份数据库配置)
Database URL:jdbc:mysql://localhost:3306/test
JDBC Driver class: com.mysql.jdbc.Driver
Username: 数据库用户名
Password: 数据库链接密码
其余选项能够默认,配置后以下:
而后配置JDBC请求,选中线程组 JDBC Users,右键,选择
在测试计划面板中,导入mysql-connector-java-5.1.40-bin.jar 以下
选中线程组 JDBC Users,右键,选择
运行线程组后,测试结果以下:
本实例中,咱们建立5个虚拟用户,每次访问发起一个请求,重复执行两次。总请求数为 (5 Users)x(1 requests)x(repeat 2 times)=10 HTTP requests。
在本实例中,咱们使用了以前教程《Python 开发与测试 Webservice(SOAP)》中介绍的方法,建立并启动webservice服务端。
选中测试计划,右键,选择 Add-> Config Element -> User Defined Variable ,配置以下:
选中测试计划,右键,选择 Add -> Config Element -> HTTP Request Defaults,配置以下
选中测试计划,右键,选择 Add -> Threads(Users) -> Thread Group,配置以下:
选中线程组 Number of Users,右键,选择 Add -> Sampler -> HTTP Request,配置以下:
1
2
3
4
5
6
7
8
9
10
|
<?
xml
version="1.0" encoding="UTF-8"?>
<
SOAP-ENV:Envelope
xmlns:ns0="spyne.examples.hello.soap" xmlns:ns1="http://schemas.xmlsoap.org/soap/envelope/" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:SOAP-ENV="http://schemas.xmlsoap.org/soap/envelope/">
<
SOAP-ENV:Header
/>
<
ns1:Body
>
<
ns0:say_hello
>
<
ns0:name
>Milton</
ns0:name
>
<
ns0:times
>1</
ns0:times
>
</
ns0:say_hello
>
</
ns1:Body
>
</
SOAP-ENV:Envelope
>
|
选中HTTP Request,右键,选择 Add -> Config Element -> HTTP Header Manager ,配置以下:
选中HTTP Request,右键,选择 Add -> Assertions -> Response Assertion,配置以下:
选中测试计划,右键,选择