一种特殊的数据库性能测试方法

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群版 2核4GB 100GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介:

4章 应用实例讲解

4.1 一种特殊的数据库性能测试方法

很多同志在进行数据方面性能测试时束手无策,前面在第二章的第二节我们已经介绍了如何应用ODBC 协议录制LoadRunner 8.0 自身带的 Flights-ODBC_Access ”例子。这里作者为您提供另一种简便的方法。问题描述:一个面向全国各个中小学的信息管理系统,随着系统被广泛的应用,访问人数的急剧增加、数据量也在飞速增长,如何为用户提供方便、快捷的应用呢?

4.1.1数据库集群项目背景介绍

经过公司相关技术人员的讨论,决定采用数据库的集群技术来解决这些问题,将先前1 台数据应用服务器扩展为3台。数据库为Mysql ,如果您关心数据库的集群技术,请查阅相关资料,在这里不再赘述。实施的整体思路是这样。由于操作人员主要是进行数据的插入工作,在某一段时间内操作人员比较集中,数据量也较大,为了估计集群后会给性能带来多大的提升,我们分别部署了两套运行环境,一套是先前的单一数据库应用服务器环境,另外一个则是三台数据库服务器进行集群。为了记录用户并发插入大数据量系统的响应时间,在相关表中添加了日期时间型字段,记录插入首条和末尾记录的时间,这样,末尾时间减去首条记录插入时间,就是多用户并发插入大批量数据的执行时间了。实施过程如下:第一步,数据库管理员用Java 写了一段代码:
import java.sql.*;
public class testclus {
       public static void main(String[] args) {
// 如果传入参数个数不等于2 ,则给出提示信息" 调用:java testclus ip:port recordcnt"
              if (args.length!=2)
              {
                     System.out.println(" 调用:java testclus ip:port recordcnt");
                     return;
              }
  // 根据传入参数,动态建立连接字符串
              String URL = "jdbc:mysql://" +args[0]+"/testclus?characterEncoding=gbk";
              int cnt = Integer.parseInt(args[1]);
              try {
  // 声明并得到起始记录插入时间
                     long timeBegin;
                     java.util.Date   d1 = new java.util.Date();
  // 数据库连接初始化操作
                     Class.forName("com.mysql.jdbc.Driver").newInstance();
                     Connection conn = DriverManager.getConnection(URL,"root","admin");
  // 循环插入记录
                     PreparedStatement pstmt = conn.prepareStatement("insert into test(cnt, timer)
values (?, now())");
                     Statement  s=conn.createStatement(ResultSet.TYPE_SCROLL_SENSITIVE,
ResultSet.CONCUR_READ_ONLY);
                     timeBegin = d1.getTime();  
                     for (int i=1; i<=cnt; i++)
                     {
                            pstmt.setInt(1, i);
                            pstmt.executeUpdate();
                            ResultSet rs=s.executeQuery("select count(*) from test");
                     }
                     conn.close();
// 得到末尾记录和起始记录插入的时间差值并输出
                     java.util.Date   d2 = new java.util.Date();  
                     System.out.println(d2.getTime()-timeBegin+"  毫秒");
              }
    // 异常处理部分
              catch(ClassNotFoundException e) {
                     System.out.println(" 找不到驱动程序");
                     e.printStackTrace();
              }
              catch(SQLException e) {
                     e.printStackTrace();
              }
              catch (Exception e) {
                     e.printStackTrace();
              }
       }
}
接下来,再建立一个批处理文件,批处理文件内容如下:
@echo off
if "%JAVA_HOME%" == "" goto error_setting
set CLASSPATH=%JAVA_HOME%"jre"lib"rt.jar
set CLASSPATH=%CLASSPATH%;mysql-connector-java-3.1.7-bin.jar;testclus.jar
%JAVA_HOME%"bin"java -classpath "%CLASSPATH%" testclus %1 %2
goto end
:error_setting
echo -------------------------------------------------------------------------------------
echo  使用方法:
echo     1. 请设置JAVA_HOME 环境变量(JDK1.4 安装路径);
echo     2. 请先将本程序所在的目录选择为当前目录后再执行。
echo -------------------------------------------------------------------------------------
goto end
:end
set CLASSPATH=
批处理接受2 个参数,第一个参数为数据库服务器的“IP 地址+: +端口号”,第二个参数为需要循环插入的数据数。如:testclus 192.168.0.45:3306 1000  ,其含义就是向IP 地址为192.168.0.45 ,端口为3306 mysql 数据库中插入1000 条记录。

4.1.2批处理方式解决方案

LoadRunner  如何调用批处理文件呢?LoadRunner  中可以调用System ()函数来调用一个可执行文件或者批处理文件等,所以我们就可以直接调用该函数,指定相关参数,为了能够进行多用户并发,需要插入集合点。相关脚本如下:
#include "web_api.h"
Action()
{
    lr_rendezvous("in");
    system("testclus 192.168.0.45:3306 1000");
    return 0;
}
为了进行集群测试,还需要另外创建两个脚本,两个脚本如下:
#include "web_api.h"
Action()
{
    lr_rendezvous("in");
    system("testclus 192.168.0.44:3306 1000");
       return 0;
}
#include "web_api.h"
Action()
{
    lr_rendezvous("in");
    system("testclus 192.168.0.46:3306 1000");
       return 0;
}
接下来,就可以分别在Controller 中进行负载了,相应场景设置如下:

4 1 :单一数据应用服务器场景设置

4 2 :三台数据应用服务器集群场景设置
而后该场景在数据库为空和数据库存在百万条记录情况下分别进行测试,经过几轮测试对结果的分析发现集群后性能比单台数据应用服务器的性能提高3 5 倍。
【作者提示】
1.           在进行性能测试的时候,一定要注意环境的一致,包括:操作系统、应用软件的版本以及硬件的配置等,而且在进行数据库方面的测试的时候一定要注意数据库的记录数、配置等要一致,只有在相同条件下进行测试,才可以对结果进行比较。
2.           如果几个脚本要实现并发,集合点一定要设置成相同的名称,如在本例中名称都为“in ”。
3.          Java 程序运行所依赖的jar 包以及批处理文件应放置到脚本所在目录,否则无法正确运行。
4.           将场景保存以后,建立一个批处理文件,通过wlrun 命令来启动Controller 执行场景也是一种非常好的方法,通过AT 命令或者计划调用批处理则控制更加灵活,与Controller 场景的定时运行取得相同的效果。在本书的第六章提供了AT 命令和计划应用的介绍,有兴趣的同志,可以看一下这部分内容。




本文转自 fish_yy 51CTO博客,原文链接:http://blog.51cto.com/tester2test/138256,如需转载请自行联系原作者

相关实践学习
通过性能测试PTS对云服务器ECS进行规格选择与性能压测
本文为您介绍如何利用性能测试PTS对云服务器ECS进行规格选择与性能压测。
目录
相关文章
|
2天前
|
存储 关系型数据库 MySQL
mysql数据库查询时用到的分页方法有哪些
【8月更文挑战第16天】在MySQL中,实现分页的主要方法包括:1)使用`LIMIT`子句,简单直接但随页数增加性能下降;2)通过子查询优化`LIMIT`分页,提高大页码时的查询效率;3)利用存储过程封装分页逻辑,便于复用但需额外维护;4)借助MySQL变量实现,可能提供更好的性能但实现较复杂。这些方法各有优缺点,可根据实际需求选择适用方案。
|
5天前
|
存储 SQL 数据库
触发器的设计、掌握存储过程的基本概念和创建、执行、删除方法。掌握数据库备份的方法和数据库恢复的方法。
这篇文章介绍了数据库中触发器的设计概念,包括创建、修改、删除触发器的方法,并通过实验内容教授如何使用SQL命令创建DML触发器以及如何利用触发器实现数据的完整性和自动化处理。
触发器的设计、掌握存储过程的基本概念和创建、执行、删除方法。掌握数据库备份的方法和数据库恢复的方法。
|
13天前
|
敏捷开发 测试技术 持续交付
软件测试中的探索性测试方法及其重要性
【8月更文挑战第6天】在软件开发周期中,测试环节是不可或缺的。它确保了产品的质量、性能与可靠性。然而,传统的测试方法往往侧重于预设的测试用例和场景,可能忽略了用户实际使用过程中的非预期行为。探索性测试(ET)应运而生,它强调测试人员的自主性和创造性,通过不断学习和适应来发现软件的潜在缺陷。本文将探讨探索性测试的概念、实施策略及其在现代软件开发中的重要性。
|
11天前
|
SQL 安全 测试技术
[go 面试] 接口测试的方法与技巧
[go 面试] 接口测试的方法与技巧
|
14天前
|
测试技术 持续交付
探索式测试:一种灵活的软件质量保证方法
在软件测试领域,探索式测试是一种与传统脚本测试截然不同的方法。它强调测试人员的自主性与创造性,允许他们在执行测试时即时设计和执行测试用例。这种方法的灵活性和适应性使其成为发现复杂软件系统中难以预测的错误的有效手段。本文将深入探讨探索式测试的核心概念、实施策略以及它在现代软件开发生命周期中的价值。
29 4
|
14天前
|
敏捷开发 测试技术
探索式测试:一种高效灵活的质量保证方法
在软件生命周期中,确保产品质量是至关重要的一环。传统的测试方法往往依赖于预设的测试用例,而忽视了测试过程中的灵活性和创造性。本文将介绍一种与传统测试截然不同的方法—探索式测试,它强调个人技能与经验的应用,鼓励测试人员发挥主观能动性,通过不断探索来发现更多潜在的软件缺陷。文章将详细阐述探索式测试的核心概念、实施步骤及其在现代软件开发中的实际应用案例,旨在为读者提供一种更为高效和灵活的测试策略。
|
19天前
|
测试技术
软件测试中的探索性测试方法
在软件开发周期中,测试环节扮演着至关重要的角色。本文将深入探讨一种灵活而高效的测试方法——探索性测试。我们将通过具体实例分析其实施过程,并讨论如何通过这种方法提高软件质量和测试效率。最后,我们提出一个开放性问题,邀请读者思考探索性测试在他们工作中的实际应用和潜在价值。 【7月更文挑战第31天】
|
20天前
|
敏捷开发 测试技术
软件测试中的探索性测试:一种灵活的质量保证方法
在软件开发周期中,测试是确保产品质量的关键步骤。传统的测试方法往往依赖于事先定义好的测试用例,但这种方法可能无法覆盖所有潜在的缺陷和场景。探索性测试(ET)作为一种更为灵活的测试方式,允许测试人员在执行测试的同时设计和适应测试用例,从而提高了测试覆盖率并发现更多隐藏的缺陷。本文将探讨探索性测试的核心概念、实施策略以及与传统测试方法的比较,旨在为软件测试专业人员提供一种更高效、适应性强的测试手段。
|
25天前
|
敏捷开发 测试技术 持续交付
探索式测试:一种高效软件质量保证方法
在软件开发的复杂性不断增加的背景下,传统的测试方法已不能完全满足快速迭代和高质量标准的要求。探索式测试(Exploratory Testing)作为一种灵活且高效的软件测试实践,正逐渐成为质量保证过程中不可或缺的一部分。本文将深入探讨探索式测试的核心理念、实施策略以及与传统测试方法相比的优势,旨在为读者提供一套完整的探索式测试框架及其在实际项目中的应用示例。
|
1天前
|
存储 SQL 关系型数据库
关系型数据库和非关系型数据库的区别和选择方法?
【8月更文挑战第17天】关系型数据库和非关系型数据库的区别和选择方法?
3 0