第四章 JMeter模拟多用户同时发送请求
1、一个简单的压力测试实战
现有一个http请求接口http://localhost:8080/goods/to_list, 要使用Jmeter对其进行压测,测试步骤如下:
a.新建一个线程组。
b. 设置线程组参数。这里配置为:10个线程,同时启动,循环一次。
c. 新增http请求默认值。 在上一步创建的线程组上,新增http请求默认值,所有的请求都会使用设置的默认值,这设置协议为http,IP为localhost,端口为8080。
d. 添加要压测的http请求。
下图第一个红框内的协议、IP、端口不需要设置,会使用步骤c中设置的默认值,只需设置请求路径Path
即可,这里填入/goods/to_list
。
e. 新增监听器,用于查看压测结果。这里添加三种:聚合报告、图形结果、用表格查看结果,区别在于结果展现形式不同。
f. 点击运行按钮开始压测,并查看结果。
五、如何查看系统负载何性能瓶颈
服务器上执行以下命令:
top
如下图所示,可以看到系统负载load average情况,1分钟平均负载,5分钟平均负载,15分钟平均负载分别是1.58, 0.50, 0.23;同时可以看到最耗费资源的进程为mysql
。
2、如何创建带参数的请求
1. 首先新建一个http请求。
2.设置请求路径,并添加参数。 如下图所示,Path
中填写请求路径,点击Add
添加参数,有一个名为token
的参数。
至此给带参数请求已创建完成,点击运行即可开始压测。
3、如何模拟设置多个变量,模拟多个用户请求接口
- 新建Csv Data Set Config设置。
2.新建配置文件config.txt,配置用户信息。 文件名随便写,里面数据每行有两个值,userId和userToken,中间用逗号隔开,我这里设置了两个用户的信息。
3.引用配置文件。 Csv Data Set Config中引用配置文件config.txt,并定义变量名为userId和userToken。
4.请求中引用配置文件中的变量。 在填写参数Value的地方不要将值写死,而是写为${变量名}这种格式,我这里想要引用配置文件中userToken的值,所以写为${userToken}。
至此配置完毕,点击运行按钮,即可开始压测。
4. jmeter模拟多用户并发
一. 100个真实的用户
- 一个账号模拟100虚拟用户同时登录和100账号同时登录
区别
- 1个账号100个人用,同时登录;
- 100个人100个账号,同时登录。
相同
- 两个都是100人同时登录,具体看项目需求。
- 账号来源
- 利用“注册”或“创建”账号接口,创建100个用户;
- “查询”接口,保存100个账号的账号、密码到一个文件。
3、提取100个账号、密码的文件
- meter脚本整体布局
线程组(一级)---->请求默认值、请求头、http请求、察看结果树(二级)----->正则表达式、BeanShell 后置处理程序(三级)。
- HTTP请求默认值:是存放系统通用ip的位置(协议:http; 服务名称或ip:127.0.0.1);
- HTTP信息头管理:接口请求之前需要带的信息,部分接口不带不能运行(Authorization、Content-Type、Accept、User-Agent),例如必须带的token就在信息头中存放;
- 登录请求:请求方法、请求路径、消息体;正则表达式提取token
- 创建请求:请求方法、请求路径、消息体;参数化用户名,创建多个用户;
- 查询账号:请求方法、请求路径、消息体;正则表达式提取用户名、密码;BeanShell 后置处理程序存储返回值到文件中
(2)查询请求中的正则表达式和BeanShell 后置处理程序
正则表达提取----->获取想要的字段内容
(详看:https://blog.csdn.net/belief_009/article/details/123051440)
- BeanShell 后置处理程序---->将提取到的字段内容存储在指定文件4.csv中
FileWriter fs=new FileWriter("D://近期//4.csv",true);
BufferedWriter out =new BufferedWriter(fs);
out.write(vars.get("username")+","+vars.get("id")); //username、id为正则定义名称
out.write(System.getProperty("line.separator")); //相当于"\n"自动换行
out.close();
fs.close();
- 线程组线程数设置数目等于提取到的条数,执行脚本得到100个用户的账号和密码
二、100个用户同时登录
- 设置线程组
线程数:并发用户数
Ramp-up时间(秒):启动所有线程所需要的时长
- 0---->代表同时并发;
- 100---->线程数100,时间100秒。代表每隔1s启动一个线程(100/100=1)
循环次数:Loop Count
- 默认值是1;
- 2---->线程数100,循环次数2。代表启动200个线程;
- 勾选“永远”,会一直执行,需要人工停止,一般配合调度器使用。
补充:同步定时器:
- 作用:阻塞线程,直到指定的线程数量到达后,在一起释放,可以瞬间产生很大的压力;
- 使用同步定时器时,循环次数要勾选为永远
2. 模拟多用户登录
线程组下添加----->CSV 数据文件设置
将存储用户账号、密码的文件引入,并命名变量名称,在登录时调用。
- 调用,传参$
- 注释:本系统账号密码一致,所以只需要调用一列值
/api/v1/oauth/token?username=${name}&password=${name}&scope=all&grant_type=password
- 执行测试,查看结果
- 100用户同时登录