使用loadrunner调用mysql API进行性能测试

其实在进行性能测试过程中,我们选择的业务都与数据库有关,即选择的业务都会经过数据库的处理,那么业务的响应时间就包含数据库查询的时间,同样如果数据库查询的时间过长,那么将直接导致事务的响应时间过长,所以数据库的调优也是性能调优的重要组成部分。

redis 我们已经学得差不多了,那么从今天起,我们来学习一下有关 "mysql 的监控与调优" 的内容。

01使用loadrunner调用mysql API进行性能测试

使用LoadRunner对mysql数据库存进行接口性能测试的步骤如下:

1将bin目录的文件libmysql.dll拷贝到loadrunner安装路径下的bin目录

2将include目录下所有的头文件拷贝到loadrunner安装路径下的include目录下

3在init.c中添加Ptt_Mysql.h头文件

复制代码
#include "Ptt_Mysql.h"

4在action.c中创建两个变量:查询字符串和连接对象

复制代码
char chQuery[128];

MYSQL *Mconn;

5在action.c中导入libmysql.dll文件

复制代码
lr_load_dll("libmysql.dll");

6创建一个连接字符串​​​​​​​

复制代码
Mconn =

lr_mysql_connect(MYSQLSERVER,MYSQLUSERNAME,MYSQLPASSWORD,MYSQLDB,atoi(PORT));
//MYSQLSERVER:服务器IP地址
//MYSQLUSERNAME:表示访问服务器的用户名
//MYSQLPASSWORD:表示访问服务器的密码
//MYSQLDB:表示访问的是哪个数据库
//PORT:表示mysql数据库访问的端口号

7在init.c中对这些连接的参数进行宏定义​​​​​​​

复制代码
#define MYSQLSERVER "localhost"

#define MYSQLUSERNAME "root"
#define MYSQLPASSWORD ""
#define MYSQLDB "ecshop"
#define PORT "3306"

8将查询字符串存储到一个变量

复制代码
sprintf(chQuery,"SELECT DISTINCT * FROM ecs_goods");

9执行查询语句

复制代码
lr_mysql_query(Mconn,chQuery);

10读取结果集中的数据

复制代码
lr_save_string(row[列号][行号].cell, "变量名");

**如:**​​​​​​​

复制代码
lr_save_string(row[0][0].cell, "goods_id");
lr_save_string(row[1][0].cell, "cart_id");
lr_save_string(row[2][0].cell, "goods_sn");

11查询执行结束后,断开数据库的连接

复制代码
lr_mysql_disconnect(Mconn);

12对脚本进行参数化​​​​​​​

复制代码
char cQuery[128];

MYSQL *Mconn;
lr_load_dll("libmysql.dll");
Mconn = lr_mysql_connect(MYSQLSERVER,USERNAME,PASSWORD,MYSQLDB,atoi(PORT));
lr_save_string(lr_eval_string("{pram_goods_id}"),"goods_id");
sprintf(cQuery,"SELECT * FROM ecs_goods WHERE goods_id =
%d",atoi(lr_eval_string("{goods_id}")));
lr_mysql_query(Mconn,cQuery);
lr_save_string(row[3][0].cell,"goods_name");
lr_error_message(lr_eval_string("{goods_name}"));
lr_mysql_disconnect(Mconn);

本章节关于"使用LoadRunner对mysql进接口"就学习到这里了,每周小编都会更新一个小知识,希望大家多多关注我们,一起来学习喔!

相关推荐
聆风吟º7 小时前
CANN开源项目深度实践:基于amct-toolkit实现自动化模型量化与精度保障策略
运维·开源·自动化·cann
Java后端的Ai之路7 小时前
【Python 教程15】-Python和Web
python
冬奇Lab9 小时前
一天一个开源项目(第15篇):MapToPoster - 用代码将城市地图转换为精美的海报设计
python·开源
剩下了什么10 小时前
MySQL JSON_SET() 函数
数据库·mysql·json
山峰哥10 小时前
数据库工程与SQL调优——从索引策略到查询优化的深度实践
数据库·sql·性能优化·编辑器
较劲男子汉11 小时前
CANN Runtime零拷贝传输技术源码实战 彻底打通Host与Device的数据传输壁垒
运维·服务器·数据库·cann
java搬砖工-苤-初心不变11 小时前
MySQL 主从复制配置完全指南:从原理到实践
数据库·mysql
wypywyp11 小时前
8. ubuntu 虚拟机 linux 服务器 TCP/IP 概念辨析
linux·服务器·ubuntu
二十雨辰11 小时前
[python]-AI大模型
开发语言·人工智能·python
Doro再努力11 小时前
【Linux操作系统10】Makefile深度解析:从依赖推导到有效编译
android·linux·运维·服务器·编辑器·vim