数据库性能测试方法讨论

发表于:2008-5-04 16:18

字体: | 上一篇 | 下一篇 | 我要投稿

 作者:陈嘉祥 王治 方耀等    来源:51Testing投稿

        摘要:在LOADRUNNER中使用脚本和JAVA程序进行数据库性能测试
        关键词:LOADRUNNER,JAVA, Benchmark
一、 前言
        在测试工作中经常需要对数据库进行性能测试,以对数据库进行调优,保证数据库的稳定和高效。
        本文使用常用的性能测试工具LOADRUNNER,JAVA和专用数据库性能测试工具Benchmark,讨论数据库性能测试的不同方法,希望能抛砖引玉,寻找出更新更好的方法。
二、 任务引入
        数据库性能测试的需求,一般来源于下面几个方面:
1、 数据库调优;
2、 数据库选型;
3、 数据库服务器选型;
4、 其他;
下面,就针对于这些常用的需求,列举几个不同的实例,共享一下测试方法。
1)  LOADRUNNER应用
        测试任务:评估某项目的核心业务逻辑(数据查询、数据复用、抽取同步整合)在不同压力下的性能表现,判断系统瓶颈,得到最优系统配置参数和建议,并为数据库的试运行工作提供可靠的性能可行性依据;
        数据查询性能指标:900个用户并发,平均响应时间在3秒以内;
        数据库性能测试需求:数据库调优或服务器选型;
include "lrd.h"

Action()
{
static LRD_INIT_INFO InitInfo = {LRD_INIT_INFO_EYECAT};

static LRD_DEFAULT_DB_VERSION DBTypeVersion[] =
{
        {LRD_DBTYPE_NONE, LRD_DBVERSION_NONE}
};

static void FAR *       OraEnv1;
static void FAR *       OraSvc1;
static void FAR *       OraSrv1;
static void FAR *       OraSes1;
static void FAR *       OraStm1;
unsigned long           rownum;

lrd_init(&InitInfo, DBTypeVersion);
lrd_initialize_db(LRD_DBTYPE_ORACLE,3, 0);
lrd_env_init(LRD_DBTYPE_ORACLE, &OraEnv1, 0, 0);
lrd_ora8_handle_alloc(OraEnv1, SVCCTX, &OraSvc1, 0);
lrd_ora8_handle_alloc(OraEnv1, SERVER, &OraSrv1, 0);
lrd_ora8_handle_alloc(OraEnv1, SESSION, &OraSes1, 0);

//连接数据库
lrd_server_attach(OraSrv1, "vmvare_192.168.1.47", -1, 0, 0);
lrd_ora8_attr_set_from_handle(OraSvc1, SERVER, OraSrv1, 0, 0);

//设定数据库密码
lrd_ora8_attr_set(OraSes1, USERNAME, "username", -1, 0);
lrd_ora8_attr_set(OraSes1, PASSWORD, "password", -1, 0);

//初始化连接session
lrd_ora8_attr_set_from_handle(OraSvc1, SESSION, OraSes1, 0, 0);

//开始连接数据库
lrd_session_begin(OraSvc1, OraSes1, 1, 0, 0);
lrd_ora8_handle_alloc(OraEnv1, STMT, &OraStm1, 0);

//设定查询语句
lrd_ora8_stmt(OraStm1, "SELECT * FROM T_TASK_ALARM_TYPE WHERE TYPE_CODE=7", 1, 0, 0);

//执行查询语句
lrd_ora8_exec(OraSvc1, OraStm1, 0, 0,&rownum, 0, 0, 0, 0, 1);

//释放连接数据库的各种变量
lrd_handle_free(&OraStm1, 0);
lrd_session_end(OraSvc1, OraSes1, 0, 0);
lrd_server_detach(OraSrv1, 0, 0);
lrd_handle_free(&OraEnv1, 0);

//lrd_end(0);
 return 0;
}
        上面的LoadRunner脚本在Virtual User Generator调试通过后,在Controller中打开,用900个模拟用户并发测试,即可得出性能指标(LoadRunner的操作这里就不在赘述,google一下)。
        从上面的例子看出,此应用比较难懂,是LoadRunner专属的方法,而且可扩展性不强。如果再遇到其他类型的数据库测试,协议将会是一个很大的问题。所以,为了容易理解,可扩展性强,引出了下面的JAVA应用方法。

版权声明:51Testing软件测试网及相关内容提供者拥有51testing.com内容的全部版权,未经明确的书面许可,任何人或单位不得对本网站内容复制、转载或进行镜像。51testing软件测试网欢迎与业内同行进行有益的合作和交流,如果有任何有关内容方面的合作事宜,请联系我们

《2023软件测试行业现状调查报告》独家发布~

精彩评论

  • gaoqing201008
    2011-12-02 12:08:57

    非常好,对我帮助挺大的。

  • lovetesting52
    2008-5-07 13:08:35

    水平不错,可惜脚本我看不懂.辛苦楼主了,争取以后多看点编码方面的知识。

  • zhangtao
    2008-5-07 09:31:10

    vmvare_192.168.1.47
    username
    password
    SELECT * FROM T_TASK_ALARM_TYPE WHERE TYPE_CODE=7

    脚本中就这几个变量吗??

  • walkman2508
    2008-5-05 15:56:24

    真是好东东~感谢分享

  • chenyunjun169
    2008-5-05 00:29:00

    好,我也正在学习这个!

关注51Testing

联系我们

快捷面板 站点地图 联系我们 广告服务 关于我们 站长统计 发展历程

法律顾问:上海兰迪律师事务所 项棋律师
版权所有 上海博为峰软件技术股份有限公司 Copyright©51testing.com 2003-2024
投诉及意见反馈:webmaster@51testing.com; 业务联系:service@51testing.com 021-64471599-8017

沪ICP备05003035号

沪公网安备 31010102002173号