首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Jmeter常用获取数据的几种方式

Jmeter常用获取数据的几种方式

作者头像
企鹅号小编
发布2018-01-16 11:34:00
1.2K0
发布2018-01-16 11:34:00
举报
文章被收录于专栏:企鹅号快讯企鹅号快讯

还没用过聊天机器人?给我发消息试试。

Jmeter在互联网测试中应用非常多,可以用来做接口测试或者性能测试,算是非常不错的一个工具。今天我们来聊聊Jmeter获取数据的几种方法。

1、手动写入

所有可以固定的参数,我们都可以通过手动写入的方式。如以下图中,HTTP信息头管理器中的Content-Type的值是application/json,通过手动写入的方式来获得数据。

2、正则表达式提取器

对于前后接口有关联,需要将前一个接口的返回值做为后一个接口的请求参数。对于这种参数,我们没有办法提前写入。为了整个项目的连贯性,所以我们需要用到正则表达式提取器来提取前一接口的返回值,然后传递给下一接口。

在第一个接口添加>后置处理区>正则表达式提取器。如下图:

要检查的响应字段:根据实际选择。

引用名称:即后面使用要引用的变量名字

正则表达式:用于将需要的数据提取出来

模板: 表示要提取第几个值,1表示第一个,2表示第二个,0表示随机,-1表示所有。

匹配数据: 0表示随机,1表示全部

数据的传递使用

前面一个接口是创建订单,从返回值中得到orderId。现在测试取消这个订单,需要orderId,我们用正则表达式提取器已经提取出来,可以直接拿来使用。

使用方法如下$:

3、读取文件

CSV Data Set Config可以从指定文件中读取数据,filename即文件路径,Variable Names即做为变量名。如果有多列就写多个,逗号隔开,如果是一列就写一个。如果读取文件第二列,前面一个逗号',var',第N列前面N-1个逗号。

4、数据库查询

在有些使用场景,我们需要去数据库中查询一些数据。这个时候我们就要用到JDBC Connection Config及JDBC Request。

JDBC Connection Config负责连接数据库,JDBC Request负责查询。

JDBC Connection Config的设置中Variable Name与JDBC Request中保持一致,正确填写Database URL, Username,Password,这样可以和数据库建立连接。

JDBC Request中Variable Name与前面一致。SQL Query中输入要执行的SQL语句。Variable Name即要传递的变量名,MySQL查询出来的数据在第几列,前面N-1个逗号。

在使用变量时需要注意,上面设置是拿的整列,在实际使用中需要用$获得第一个数据,如"token":"$"。当然此处也可以获取其他指定行数据。

5、使用随机数

在配置元件中有个Random Variable,非常好用。输入最大和最小值。

6、用时间戳做为变量

有时候随机数可能不能满足我们对于参数的要求,我们可以采用时间戳+随机数的方式,大大减低数据重复的可能性。$获取时间戳。

7、返回值存入文件再使用

前面我们说了采用正则表达式提取器来传递参数,能满足我们大部分场景,当使用场景如下时就会显得不那么好用了:在压力测试时,我们需要每个用户都是登录情况下操作。如果我们在前面调用登录接口,势必大大影响整个系统的处理能力,这样不能能客观得到接口的性能。

我们可以采用如下处理方式,批量注册或者登陆一批用户(当然总数是够跑一次测试的),把他们的登录信息存入一个文档。 再把他们从文件中读取处理,放入headers。

登录接口加入后置处理器正则表达式提取器及BeanShell PostProcessor,正则表达式提取器来提取,采用beanshell脚本来做到存储。

今天只是粗略介绍了Jmeter获取数据的几种方式。当然可能有其他更好,更多的方式,欢迎讨论。

本文来自企鹅号 - 全球大搜罗媒体

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文来自企鹅号 - 全球大搜罗媒体

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
数据库
云数据库为企业提供了完善的关系型数据库、非关系型数据库、分析型数据库和数据库生态工具。您可以通过产品选择和组合搭建,轻松实现高可靠、高可用性、高性能等数据库需求。云数据库服务也可大幅减少您的运维工作量,更专注于业务发展,让企业一站式享受数据上云及分布式架构的技术红利!
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档