級別: 初級
Kulvir Singh Bhogal, IBM 電子商務(wù)顧問, Austin, TX
2004 年 11 月 01 日
作者 Kulvir Singh Bhogal 介紹了一個叫作 JMeter 的開放源代碼工具,該工具可以測量 DB2 Universal Database 的查詢性能和吞吐量。
簡介
在當(dāng)今快節(jié)奏的世界中,只是完成工作是不夠的。完成工作,并且要以簡便的方式完成工作,這才是關(guān)鍵。數(shù)據(jù)庫世界也不能幸免這種對性能的渴求?蛻粝M軌蜓杆俣行У乇4婧吞崛∑鋽(shù)據(jù)。在許多場合設(shè)置中,IBM 的 ® DB2® Universal Database TM 都擁有的性能跟蹤記錄,于眾多的數(shù)據(jù)庫競爭對手。
不幸的是,由于數(shù)據(jù)庫或者配置中的某些設(shè)計缺陷,許多 DB2 用戶可能無法獲得 DB2 性能的所有益處。有許多關(guān)于 DB2 性能調(diào)整的文章和論文,DB2 中也有許多能夠進(jìn)行深入分析的好工具。我將在這篇文章中介紹一個工具 —— Apache 的 JMeter,這是另外一個可以添加到您的工具箱中的工具,它可以幫助您了解數(shù)據(jù)庫的性能,還能幫助您進(jìn)行模擬測試。
關(guān)于 Apache JMeter
JMeter 是 Apache Jakarta 項目麾下的一個產(chǎn)品。JMeter 是基于 Java TM Swing 的桌面應(yīng)用程序,是為進(jìn)行負(fù)載測試、測量系統(tǒng)性能而設(shè)計的。初,它是為測試 Web 應(yīng)用程序而設(shè)計的。但是它后來進(jìn)行了擴展,現(xiàn)在您已經(jīng)可以用它來測試關(guān)系數(shù)據(jù)庫了(通過 JDBC TM)。在 JMeter 的官方站點http://jakarta.apache.org/jmeter/上,您可以了解關(guān)于它的更多內(nèi)容。
利用 JMeter,您可以確保您的數(shù)據(jù)庫可以滿足某些指標(biāo)(例如能夠處理一定數(shù)量的并發(fā)用戶)。模擬測試是成功項目的關(guān)鍵。JMeter 可以針對 DB2 模擬出繁重的負(fù)載。這可以通過 JMeter 的多線程框架來實現(xiàn)。JMeter 的多線程框架允許大量線程進(jìn)行并發(fā)采樣。正如您將在本文后面看到的,JMeter 能為您提供圖形化的反饋。
獲得 JMeter 并設(shè)置您的測試環(huán)境
您可以從http://jakarta.apache.org/builds/jakarta-jmeter/release/下載 JMeter 的新發(fā)行版。在我撰寫這篇文章時,新的 JMeter 版本是 1.8。JMeter 要求在 Sun 的 JDK1.4(或者更高)環(huán)境中工作。IBM JDK(指當(dāng)前版本)似乎與 JMeter 不兼容。JMeter 已經(jīng)在各種 UNIX® 變體 (包括 Solaris 和 Linux) 和 Windows®(98®、NT® 和 2000®)上通過了測試。
為了方便我們對 DB2 進(jìn)行的 JDBC 測試,需要把 DB2 的 JDBC 驅(qū)動程序復(fù)制到 <jmeter 安裝目錄>jakarta-jmeterlib 目錄下。對于 DB2 8.1 ,在默認(rèn)安裝情況下,DB2 驅(qū)動程序的位置是 c:program filesibmsqllibjavadb2java.zip。奇怪的是,如果 DB2 的 JDBC 驅(qū)動程序以 zip 文件命名,JMeter 將找不到 DB2 的 JDBC 驅(qū)動程序。要解決這個問題,您必須將文件名更改為 .JAR 文件。您可以把 lib 目錄中的文件改名為 db2java.jar。另一方面,如果想測試 DB2 8.1 Java Common Client (JCC) 驅(qū)動程序,只需將 db2jcc.jar文件復(fù)制到 JMeter 的 lib 目錄下即可(不用更改名稱)。
在沙箱中放沙子
在我們開始使用 JMeter 之前,我們需要建立一個有一些測試數(shù)據(jù)的數(shù)據(jù)庫。
在 DB2 的命令行處理器中輸入以下內(nèi)容:
create db loaddb
連接 loaddb 數(shù)據(jù)庫,如下所示:
connect to loaddb user db2admin using db2admin
建立一個表,保存我們的測試數(shù)據(jù):
create table loadtable (col1 varchar(25) not null,
col2 varchar(25) not null,
col3 varchar(25) not null)
用大量記錄填充表,這樣我們才能用 JMeter 來測試查詢性能。我用了一個小小的 JDBC 程序來完成這項工作,在清單1中可以看到它,該程序?qū)⒃诳裳b入表中插入 30,000 條記錄。然后編譯并執(zhí)行這段代碼,用測試數(shù)據(jù)填充可裝入表。
清單 1. 將記錄插入數(shù)據(jù)庫
package com.ibm.jmetertest;
import java.sql.*;
public class JMeterPopulator
{
public static void main(String[] args)
{
try
{
Class.forName("COM.ibm.db2.jdbc.app.DB2Driver");
String dbName = "loaddb";
String url = "jdbc:db2:" + dbName;
String userName = "db2admin";
String password = "db2admin";
Connection con
= DriverManager.getConnection(url,userName, password);
int numOfTestRecords = 30000;
PreparedStatement statement
= con.prepareStatement("INSERT INTO LOADTABLE VALUES(?,?,?)");
for (int i =0; i<numOfTestRecords; i++)
{
statement.setString(1,"Col1Test-" + i);
statement.setString(2,"Col2Test-" + i);
statement.setString(3,"Col3Test-" + i);
statement.executeUpdate();
System.out.println(i);
}
}
catch(Exception e)
{
System.out.println("An error has occurred: " + e.toString());
e.printStackTrace();
}
}
}
現(xiàn)在我們有了相當(dāng)數(shù)量的記錄,讓我們用 JMeter 來測試一下查詢性能。
進(jìn)入 JMeter
要啟動 JMeter,需要運行 <jmeter 安裝目錄 >jakarta-jmeterin 目錄下的 jmeter.bat 文件。
當(dāng)啟動 JMeter 時,您會看到一個主屏幕,屏幕左邊有一個面板,其中還沒有定義測試計劃(參見 圖 1)。在 JMeter 中,一個測試計劃是由一個或多個線程組構(gòu)成的。線程代表模擬用戶, 線程組(thread group)是一組模擬用戶。
圖 1. JMeter 的主屏幕
讓我們從建立線程組開始。方法是右擊 TestPlan 節(jié)點,選擇 Add => Thread Group。參見 圖 2。