使用Jmeter进行性能测试实战:详解HTTP请求和JDBC request进阶篇

Jmeter作为性能或自动化测试工具在开展工作时,其扮演的角色是模拟用户操作,而后记录响应结果并统计如响应时间、TPS等性能指标,而实现请求访问这个场景就要用到工具中取样器的相关功能。

取样器的主要用来模拟用户操作向服务器发出各位请求,如webservice或Java请求等,然后根据请求获取对应的响应信息,同时配合监听器结果树等验证该接口的响应是否合理。在Jmeter中取样器的种类很多,常见的主要有HTTP请求和JDBC reques两类。

一、HTTP请求

1.首先在测试计划下添加线程组,在线程组中添加取样器<HTTP请求>,如图所示:

2.相关参数设置说明:

名称:定义改取样器请求目标的标识,可按需设置。

注释:按需备注,可为空。

基本:

·协议:协议支持“http”和“https”

·服务器名称或IP/端口:此处填写请求的目标服务端地址,端口号默认为80。

·http请求方法:常见的有POST和GET,两者均作为TCP链接并无本质区别

·路径:请求资源路径

·内容编码:如果内容含有中文一般为utf-8

·自动重定向:针对GET和HEAD请求如包含重定向则可自动跳转目标页面,但不记录前置请求,无法做内容关联

·跟踪重定向:Jmeter默认选项可跟踪定向并将请求返回记录与结果树中,可对响应进行关联。

·使用keepalive:保持http中的请求alive,默认勾选

·对POST使用multipart/form-data、与浏览器兼容的头:当方法为post时默认勾选该两项

立即加入Python自动化学习交流群,内含直播课+实战+面试资料​mp...com/s/mCYavUF7H9ntywyi1sTWzg

高级:

·客户端实现:选择http请求方式,常见为HttpClien4和Java。

·超时:连接超时时间、响应等待超时时间

·从HMTL文件嵌入资源:当需要获取响应中如图片、动画等内容时,勾选此项可对响应HTML进行解析。可以对并行资源进行定义,默认为6

·源地址:此属性用于实现动态IP访问,使得Jmeter具有多个IP地址

·代理服务器:此属性用于配置网络代理

·其他任务:勾选该项实现对响应报文的筛选,既仅保留响应数据的MD5值,剔除冗余信息

二、JDBC Request

JDBC英文名为Java Data Base Connectivity(Java数据库连接),它是Java编程语言和各类数据库之间连接标准的Java API,可以认为JDBC规范了它提供的接口,使得由Java编写的应用程序可以便捷访问底层数据库。但不同的数据库访问往往需要不同的驱动,所以在使用JDBC取样前要将目标数据库驱动放置在Jmeter的lib目录下,然后配合JDBC Connection Configuration联通数据库。

1.首先在线程组下添加配置元件->JDBC Connection Configuration:

·Variable Name for created pool: 该变量名与Request中连接池变量名相同

·Max Number of Connections:数据库连接池的最大连接数

·Max Wait (ms) :连接超时限额,超过反回连接最大等待时间则报错

·Time Between Eviction Runs (ms):当前连接池保持该时长无交互则关闭

·Auto Commit :自动执行SQL语句

·Transaction Isolation:事务间隔级别设置

·Test While Idle:空闲时判断连接连接状态

·Soft Min Evictable Idle Time(ms):连接池闲置状态下保持连接的最小时长

·validation query:如超5秒无请求则调用该SQL测试连接有效性

·Database URL:数据库地址

·JDBC Driver class:选择lib目录下存放对应数据库的驱动

·Username:数据库用户

·Password:数据库密码

2.然后在该线程组下添加取样器->JDBC Request:

·Variable name of Pool:数据库连接池变量名

·Query:填列待执行数据库SQL

·parameter valus:数据的参数值

·parameter types:数据的参数类型

·variable names:SQL返回的变量名,多个变量以逗号隔开

·result variable name:保存某变量的全部返回结果(引用${id_n}调用多行数据)

·query timeout:查询超时时间

·handle result set:定义如何处理callable statements语句结果

取样器作为用来模拟用户请求操作和获取返回影响数据的模块,功能类似于LoadRunner中的Vuser;,以上介绍的两种请求方式可分别实现从前端请求访问和直接对数据库进行压测,作为自动化测试和性能测试的前置步骤,HTTP和JDBC使用频次高较为常见,日常测试中需要熟练掌握。