LoadRunner驱动MySQL性能测试(lib库实现)
作者:网络转载 发布时间:[ 2015/3/31 11:35:53 ] 推荐标签:性能测试工具
前言
因为loadrunner原生未提供针对mysql测试的功能
国内网络上流传的都是ODBC连接mysql进行性能测试,过程较为繁琐
而LR本身推荐的是使用提供的dll库或者自行编写dll库进行测试。
只要能在网上找到支持自编写dll库的license即可
本文方法参考的主要是Bish.co.uk论坛,有mysql,php和loadrunner板块,
使用它们编写的mysql链接库
———–待测试库环境准备———————-
GRANT ALL PRIVILEGES ON*.*TO'root'@'windows IP'
IDENTIFIED BY'root'WITHGRANTOPTION;
配置好测试数据库和表
—————–LoadRunner运行库准备———————
a.解压MySQL LoadRunner libraries.zip版本1版本2中的文件至LR安装目录
b.在LR的vuser脚本的init中加入实例信息
#include"Ptt_Mysql.h"
#define MYSQLSERVER"192.168.2.5"
#define MYSQLUSERNAME"root"
#define MYSQLPASSWORD"root"
#define MYSQLDB"tpch_1"
#define MYSQLPORT"5029"
c.在action脚本中每个sql语句前加入
lr_load_dll("libmysql.dll");
———————–vu脚本编写方法,c语言————————–
//action中加入
char chQuery[128];
MYSQL*Mconn;
//将sql语句保存在char中
lr_load_dll("libmysql.dll");
//每个sql前加入读取dll库
Mconn=lr_mysql_connect(MYSQLSERVER,MYSQLUSERNAME,
MYSQLPASSWORD,MYSQLDB,
atoi(MYSQLPORT));
//从init的define中读取连接参数
sprintf(chQuery,"select N_NATIONKEY,N_NAME,N_REGIONKEY from
nation limit 3;");
lr_mysql_query(Mconn,chQuery);
//在输出中打印语句,调用dll中的lr_mysql_query方法执行语句
lr_save_string(row[0][0].cell,"sN_NATIONKEY");
lr_save_string(row[1][0].cell,"sN_NAME");
lr_save_string(row[2][0].cell,"sN_REGIONKEY");
//结果集要保存到多维数组中。。也可以直接忽略输出
lr_output_message(lr_eval_string("N_NATIONKEY:{sN_NATIONKEY};
N_NAME:{sN_NAME};N_REGIONKEY Description:{sN_REGIONKEY}"));
lr_save_string(row[0][1].cell,"sN_NATIONKEY");
lr_save_string(row[1][1].cell,"sN_NAME");
lr_save_string(row[2][1].cell,"sJobDesc");
lr_output_message(lr_eval_string("N_NATIONKEY:{sN_NATIONKEY};
N_NAME:{sN_NAME};N_REGIONKEY Description:{
//vu_end中加入
lr_mysql_disconnect(Mconn);
//断开连接
———–安装对linux的资源监控———
a.安装rsh
一般都有
rpm-q rsh
b.安装rstat开源软件
下载
http://sourceforge.net/projects/rstatd/files/rstatd/4.0.1/rpc.rstatd-4.0.1.tar.gz/download
#tar–xzvf rpc.rstatd-4.0.1.tar.gz
#./configure
//配置
#make
//编译
#make install
//安装
#rpc.rstatd
//启动rstatd进程
c.查看rstatd是否启动:
#rpcinfo-p
如果能看到:
100001 5 udp 892 rstatd
100001 3 udp 892 rstatd
100001 2 udp 892 rstatd
100001 1 udp 892 rstatd
说明rstatd服务已经启动。可以用LR去监视了。
d.在LoadRunner Controller的run界面中,添加System Resource Graphs下的Unix Resource,在Unix Resource图上右键Add Measurements,然后点击Add,填写ip如192.168.1.99,默认只有三个指标,在下面的Add中可以添加其他指标。
—————-lr control——-
启动controller设定vu用户数和迭代次数,配置后对linux的资源监控后即可进行测试,之后调用analyse进行分析。
不过因为不是原生的支持,analyse分析内容有限。
注:对于dml也可进行测试,但要做好数据的规划,如insert 10条,delete10条
相关推荐
更新发布
功能测试和接口测试的区别
2023/3/23 14:23:39如何写好测试用例文档
2023/3/22 16:17:39常用的选择回归测试的方式有哪些?
2022/6/14 16:14:27测试流程中需要重点把关几个过程?
2021/10/18 15:37:44性能测试的七种方法
2021/9/17 15:19:29全链路压测优化思路
2021/9/14 15:42:25性能测试流程浅谈
2021/5/28 17:25:47常见的APP性能测试指标
2021/5/8 17:01:11