博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Jmeter的操作使用
阅读量:5014 次
发布时间:2019-06-12

本文共 2058 字,大约阅读时间需要 6 分钟。

一、jmeter 添加http请求:

1、从测试计划添加线程组

2、从线程组添加http请求

3、在http请求中写入接口url、路径、请求方式、参数

4、从线程组添加察看结果树调用接口、查看返回值

 二、Jmeter添加header请求

1、从线程组-配置元件-添加Http 信息头管理器

 

2、添加头部信息

 

三、Jmeter-http接口脚本添加cookie

1、从线程组-配置元件-添加Cookie管理器

2、添加cookie值:

四、Jmeter-三种参数化的方式

1、用户自定义变量:这种就是为了方便管理参数,只能有一个值,比如说ip地址不经常变化的

把需要参数化的信息取一个名称,比如IP ,使用该参数化方式:${ip}

2、使用函数助手对话框:

       可以按照规则生成一些参数,点击生成拷贝使用。

最常用的有:

      1、随机数__Random,可以在你指定的一个范围内取随机值;
      2、取当前时间__time,如果在有一些需要传时间的情况下可以使用,日期格式是:
       yyyy-MM-dd HH:mm:ss 年-月-日-小时:分钟:秒
      3、取唯一id,__UUID,这个就是每次会生成一个随机的uuid,都是唯一的

 

 

3、从文件里读取参数

从文件中读取的话,三个步骤

1、读取文件
2、取文件内容里面的参数,给它一个名字
3、使用值
从文件读取的话,需要在线程组里面添加一个CSV Data Set Config,它就是做前面两步的操作的

 

 

 

 

 

 

五、Jmeter断言:

断言是用来验证预期结果是否正确,,这样我们就可以通断言来检查返回结果,测试是否通过。

 

 

 六、Jmeter关联(之一)

首先下载插件

下载后解压以后将lib和lib/ext中的jar包放到安装目录对应位置,重启即可

 在线程组中后置处理器中添加JSON Extractor

 

 

variable names : 名称

JSONPath Expression:JSON表达式
Match Numbers:匹配哪个,可为空即默认第一个
Default Value:未取到值的时候默认值

 从结果中提取需要的参数 执行一遍结果:

请求的返回值为:

{

        "error_code": 0,
        "login_info": {
                "login_time": "20180522230335",
                "sign": "a5565aa7d609ee8552fa7e1cd8c88394",
                "userId": 11
        }
}

 需要取sign和userid 二个值作为参数,分析出sign 的路径是:{login_info {sign}}

json数据就是:$longin_info.sign

 查询资料中有人遇见的坑 顺便记录一下:

某一请求的返回值为:

{"statusCode":200,"data":{"userId":"4a2cbe616eb74f0d99190af072c8dea6","token":"37e7a9e198186f5a443e50e6138a5bd20bd"}}
  • 1

这里因为返回的是json数据,$.data.token,获取token的值

但是有碰到一个坑

另外一个接口请求返回值为:

{"statusCode":200,"data":[{"code":"407949","id":"aa477ad2085d492a99b877d14343d68d","name":"90一中4545"}]}
  • 1

同样,使用$.data.id去提取id的值时,发现获取到的数据为空

原来这个responses 的data为数组,故应为 $.data[0].id 提取第1个值

七、Jmeter操作mysql

1、导入jdbc的jar包,因为jmeter本身不能直接连接mysql,所以需要导入第三方的jar包,来连接mysql
Jmeter导入jdbcjar包
 

2、创建数据库连接配置,mysql的url、端口号、账号、密码

Jmeter配置mysql连接

1、添加一个JDBC Connection Configuration
2、配置mysql连接池的名称,后面发sql请求的时候指定连接哪里
3、数据库的url:jdbc:mysql://192.168.31.116:3306/jxz?useUnicode=true&characterEncoding=utf8&allowMultiQueries=true

characterEncoding=utf8(防止乱码 )   allowMultiQueries=true (可以执行所有数据库)

4、数据库驱动:这里就是指定连接什么类型的数据库,mysql、oracle、SqlServer等等

5、账号密码

 

 

 

3、写sql,执行sql

1 添加JDBC Request

2 添加数据库名字

3 执行数据库

 

 

4、 Jmeter压力测试结果查看

 

 

转载于:https://www.cnblogs.com/niel/p/9080547.html

你可能感兴趣的文章
[BZOJ 2818]Gcd
查看>>
160. Intersection of Two Linked Lists
查看>>
人生苦短,我用python-- Day11
查看>>
ehcache memcache redis 三大缓存男高音_转
查看>>
Java构造方法、重载及垃圾回收
查看>>
.Net Core AES加密解密
查看>>
Spring Quartz实现任务调度
查看>>
python | 桶排序、冒泡排序、选择排序、去重
查看>>
Mac升级bash到最新版本
查看>>
数据库多对多关联表(Python&MySQL)
查看>>
[实变函数]1.2 集合的运算
查看>>
第06天
查看>>
设计模式的征途—5.原型(Prototype)模式
查看>>
simple java mail
查看>>
信息建模
查看>>
Mybatis 数据库物理分页插件 PageHelper
查看>>
虚函数、纯虚函数详解
查看>>
MySQL - 常用命令及常用查询SQL
查看>>
C# .NET MVC 接收 JSON ,POST,WCF 无缝隙切换
查看>>
android获取USB设备的名称
查看>>