1. JdbcRunnerの概要¶
この章では、JdbcRunnerの概要を説明します。
1.1. JdbcRunnerとは¶
JdbcRunnerとは、Oracle Database、MySQL、PostgreSQLなどのRDBMSを対象とした負荷テストツールです。 OLTPを想定した比較的短いトランザクションを定義して多重実行し、スループットとレスポンスタイムを測定できます。
1.2. JdbcRunnerの特長¶
1.2.1. RDBMS非依存¶
JdbcRunnerはJavaで実装されているため、JDBCドライバーが提供されているRDBMSであれば製品を問わず使用できます。
1.2.2. 自由度の高いテストシナリオ¶
JdbcRunnerでは負荷テストのシナリオをスクリプトで記述します。 これによって入力データの生成や条件分岐を柔軟に行うことができ、より実際のシステムに近い状況をシミュレートできます。 スクリプト言語にはJavaScriptを採用しています。
1.2.3. コネクションプールを利用¶
コネクションプールとして、Apache Tomcatで用いられているApache Commons DBCPを使用しています。 これによって一般的なJakarta EEの構成に近い挙動を再現しています。
ただし、コネクションプールを利用していないシステムとは挙動が大きく異なることになります。
1.2.4. パラメーターのバインド機構を利用¶
JdbcRunnerからSQLを発行する際は、必ずPreparedStatementを用いパラメーターをバインドするように設計しています。 他の負荷テストツール、特にMySQLをターゲットにしたものはパラメーターのバインド機構を利用していないものが多いのですが、それらに比べより実際のシステムに近い性能特性を得ることができます。
ただし、パラメーターのバインド機構を利用していないシステムとは性能の傾向が大きく異なることになります。
1.3. 動作要件¶
JdbcRunnerを動作させるには、以下のソフトウェアが必要です。
Java 17の実行環境
各RDBMS用のJDBCドライバー
JavaはLinuxの場合ディストリビューションに同梱されています。 Windowsの場合は Adoptium などからダウンロードしてください。
JDBCドライバーは多くの場合RDBMSの開発元が提供しています。 なおJdbcRunnerはMySQLとPostgreSQLのJDBCドライバーを内蔵しているため、MySQLとPostgreSQLについては別途JDBCドライバーを用意する必要はありません。
1.4. インストール方法¶
インストーラーはありません。 アーカイブファイルを任意のディレクトリーに展開してください。
1.5. アンインストール方法¶
アンインストーラーはありません。 展開されたファイルを単純に削除してください。
1.6. ライセンス¶
JdbcRunner本体は、MITライセンスです。
JdbcRunnerでは以下のライブラリーをそれぞれのライセンスに従って利用しています。 JdbcRunnerを修正して再頒布する場合は、これらのライセンスも遵守する必要があります。
Apache Commons CLI (Apache License 2.0)
Apache Commons DBCP (Apache License 2.0)
Apache Commons Pool (Apache License 2.0)
Apache log4j (Apache License 2.0)
Mozilla Rhino (Mozilla Public License 2.0)
MySQL Connector/J (GNU General Public License v2 with the Universal FOSS Exception, Version 1.0)
PostgreSQL JDBC Driver (二条項BSDライセンス)