2000-07-31 21:29:14 +02:00
|
|
|
The MySQL Benchmarks
|
|
|
|
|
2003-12-03 11:48:34 -06:00
|
|
|
These tests require a MySQL version of at least 3.20.28 or 3.21.10.
|
2000-07-31 21:29:14 +02:00
|
|
|
|
|
|
|
Currently the following servers are supported:
|
|
|
|
MySQL 3.20 and 3.21, PostgreSQL 6.#, mSQL 2.# and Solid Server 2.2
|
|
|
|
|
2003-12-02 18:14:56 -06:00
|
|
|
The benchmark directory contains the query files and raw data files used to
|
|
|
|
populate the MySQL benchmark tables. In order to run the benchmarks, you
|
|
|
|
should normally execute a command such as the following:
|
2000-07-31 21:29:14 +02:00
|
|
|
|
2001-06-08 18:16:20 -05:00
|
|
|
run-all-tests --server=mysql --cmp=mysql,pg,solid --user=test --password=test --log
|
2000-07-31 21:29:14 +02:00
|
|
|
|
2003-12-02 18:14:56 -06:00
|
|
|
This means that you want to run the benchmarks with MySQL. The
|
|
|
|
limits should be taken from all of MySQL, PostgreSQL, and Solid.
|
|
|
|
The login name and password for connecting to the server both are
|
|
|
|
``test''. The result should be saved as a RUN file in the output
|
2000-07-31 21:29:14 +02:00
|
|
|
directory.
|
|
|
|
|
2003-12-02 18:14:56 -06:00
|
|
|
When run-all-tests has finished, will have the individual results and the
|
2000-07-31 21:29:14 +02:00
|
|
|
the total RUN- file in the output directory.
|
|
|
|
|
2003-12-02 18:14:56 -06:00
|
|
|
If you want to look at some old results, use the compare-results script.
|
|
|
|
For example:
|
2000-07-31 21:29:14 +02:00
|
|
|
|
|
|
|
compare-results --dir=Results --cmp=mysql,pg,solid
|
|
|
|
compare-results --dir=Results --cmp=mysql,pg,solid --relative
|
|
|
|
|
|
|
|
compare-results --dir=Results --cmp=msql,mysql,pg,solid
|
|
|
|
compare-results --dir=Results --cmp=msql,mysql,pg,solid --relative
|
|
|
|
|
2003-12-02 18:14:56 -06:00
|
|
|
compare-results --dir=Results --server=mysql --same-server --cmp=mysql,pg,solid
|
2000-07-31 21:29:14 +02:00
|
|
|
|
2003-12-02 18:14:56 -06:00
|
|
|
Some of the files in the benchmark directory are:
|
2000-07-31 21:29:14 +02:00
|
|
|
|
|
|
|
File Description
|
|
|
|
|
|
|
|
Data/ATIS Contains data for 29 related tables used in the ATIS tests.
|
|
|
|
Data/Wisconsin Contains data for the Wisconsin benchmark.
|
|
|
|
Results Contains old benchmark results.
|
|
|
|
Makefile.am Automake Makefile
|
|
|
|
README This file.
|
2003-12-02 18:14:56 -06:00
|
|
|
test-ATIS.sh Creation of 29 tables and a lot of selects on them.
|
2000-07-31 21:29:14 +02:00
|
|
|
test-connect.sh Test how fast a connection to the server is.
|
|
|
|
test-create.sh Test how fast a table is created.
|
|
|
|
test-insert.sh Test create and fill of a table.
|
2003-12-03 21:10:44 -06:00
|
|
|
test-wisconsin.sh A port of the PostgreSQL version of this benchmark.
|
2003-12-02 18:14:56 -06:00
|
|
|
run-all-tests Use this to run all tests. When all tests are run,
|
2003-12-03 21:10:44 -06:00
|
|
|
use the --log and --use-old options to get a RUN-file.
|
2003-12-02 18:14:56 -06:00
|
|
|
compare-results Generates a comparison table from different RUN files.
|
2003-12-03 21:10:44 -06:00
|
|
|
server-cfg Contains the limits and functions for all supported
|
2000-07-31 21:29:14 +02:00
|
|
|
SQL servers. If you want to add a new server, this
|
|
|
|
should be the only file that neads to be changed.
|
|
|
|
|
|
|
|
|
2003-12-03 21:10:44 -06:00
|
|
|
Most of the tests should use portable SQL to make it possible to
|
2000-07-31 21:29:14 +02:00
|
|
|
compare different databases. Sometimes SQL extensions can make things
|
|
|
|
a lot faster. In this case the test may use the extensions if the --fast
|
|
|
|
option is used.
|
|
|
|
|
|
|
|
Useful options to all test-scripts (and run-all-tests):
|
|
|
|
|
|
|
|
--host=# Hostname for MySQL server (default: localhost)
|
|
|
|
--db=# Database to use (default: test)
|
|
|
|
--fast Allow use of any non-standard SQL extension to
|
2003-12-02 18:14:56 -06:00
|
|
|
get things done faster.
|
2000-07-31 21:29:14 +02:00
|
|
|
--lock-tables Use table locking to get more speed.
|
|
|
|
|
2003-12-03 11:48:34 -06:00
|
|
|
From a text at http://www.mgt.ncu.edu.tw/CSIM/Paper/sixth/11.html:
|
2000-07-31 21:29:14 +02:00
|
|
|
|
|
|
|
The Wisconsin Benchmark
|
|
|
|
|
|
|
|
The Wisconsin Benchmark described in [Bitton, DeWitt, and Turbyfill
|
|
|
|
1983] [Boral and DeWitt 1984] [Bitton and Turbyfill 1985] [Bitton and
|
|
|
|
Turbyfill 1988], and [DeWitt 1993] is the first effort to
|
|
|
|
systematically measure and compare the performance of relational
|
|
|
|
database systems with database machines. The benchmark is a
|
|
|
|
single-user and single-factor experiment using a synthetic database
|
|
|
|
and a controlled workload. It measures the query optimization
|
2003-12-02 18:14:56 -06:00
|
|
|
performance of database systems with 32 query types to exercise the
|
2000-07-31 21:29:14 +02:00
|
|
|
components of the proposed systems. The query suites include
|
|
|
|
selection, join, projection, aggregate, and simple update queries.
|
|
|
|
|
|
|
|
The test database consists of four generic relations. The tenk
|
|
|
|
relation is the key table and most used. Two data types of small
|
2003-12-02 18:14:56 -06:00
|
|
|
integer numbers and character strings are utilized. Data values are
|
2000-07-31 21:29:14 +02:00
|
|
|
uniformly distributed. The primary metric is the query elapsed
|
|
|
|
time. The main criticisms of the benchmark include the nature of
|
|
|
|
single-user workload, the simplistic database structure, and the
|
|
|
|
unrealistic query tests. A number of efforts have been made to extend
|
|
|
|
the benchmark to incorporate the multi-user test. However, they do
|
|
|
|
not receive the same acceptance as the original Wisconsin benchmark
|
|
|
|
except an extension work called the AS3AP benchmark.
|