Using Your Own Benchmarks
642
To use the benchmark suite, the following requirements must be satisfied:
• The benchmark suite is provided with MySQL source distributions. You can either download a
released distribution from
http://dev.mysql.com/downloads/
, or use the current development source
tree. (See
Section 2.17.2, “Installing MySQL from a Development Source Tree”
.)
• The benchmark scripts are written in Perl and use the Perl DBI module to access database servers,
so DBI must be installed. You also need the server-specific DBD drivers for each of the servers you
want to test. For example, to test MySQL, PostgreSQL, and DB2, you must have the
DBD::mysql
,
DBD::Pg
, and
DBD::DB2
modules installed. See
Section 2.22, “Perl Installation Notes”
.
After you obtain a MySQL source distribution, you can find the benchmark suite located in its
sql-
bench
directory. To run the benchmark tests, build MySQL, and then change location into the
sql-
bench
directory and execute the
run-all-tests
script:
shell>
cd sql-bench
shell>
perl run-all-tests --server=server_name
server_name
should be the name of one of the supported servers. To get a list of all options and
supported servers, invoke this command:
shell>
perl run-all-tests --help
The
crash-me
script also is located in the
sql-bench
directory.
crash-me
tries to determine what
features a database system supports and what its capabilities and limitations are by actually running
queries. For example, it determines:
• What data types are supported
• How many indexes are supported
• What functions are supported
• How big a query can be
• How big a
VARCHAR
column can be
For more information about benchmark results, visit http://www.mysql.com/why-mysql/benchmarks/.
8.1.4. Using Your Own Benchmarks
You should definitely benchmark your application and database to find out where the bottlenecks are.
After fixing one bottleneck (or by replacing it with a “dummy” module), you can proceed to identify the
next bottleneck. Even if the overall performance for your application currently is acceptable, you should
at least make a plan for each bottleneck and decide how to solve it if someday you really need the
extra performance.
For examples of portable benchmark programs, look at those in the MySQL benchmark suite. See
Section 8.1.3, “The MySQL Benchmark Suite”
. You can take any program from this suite and modify it
for your own needs. By doing this, you can try different solutions to your problem and test which really
is fastest for you.
Another free benchmark suite is the Open Source Database Benchmark, available at
http://
osdb.sourceforge.net/
.
It is very common for a problem to occur only when the system is very heavily loaded. We have
had many customers who contact us when they have a (tested) system in production and have
encountered load problems. In most cases, performance problems turn out to be due to issues of
basic database design (for example, table scans are not good under high load) or problems with the
Summary of Contents for 5.0
Page 1: ...MySQL 5 0 Reference Manual ...
Page 18: ...xviii ...
Page 60: ...40 ...
Page 396: ...376 ...
Page 578: ...558 ...
Page 636: ...616 ...
Page 844: ...824 ...
Page 1234: ...1214 ...
Page 1427: ...MySQL Proxy Scripting 1407 ...
Page 1734: ...1714 ...
Page 1752: ...1732 ...
Page 1783: ...Configuring Connector ODBC 1763 ...
Page 1793: ...Connector ODBC Examples 1773 ...
Page 1839: ...Connector Net Installation 1819 2 You must choose the type of installation to perform ...
Page 2850: ...2830 ...
Page 2854: ...2834 ...
Page 2928: ...2908 ...
Page 3000: ...2980 ...
Page 3122: ...3102 ...
Page 3126: ...3106 ...
Page 3174: ...3154 ...
Page 3232: ...3212 ...