本稿の目的
- JMeterのデメリットを改善したソフトウェアを開発するための第一歩として使い方、pros/consを整理します。
- JMeterの負荷テストはローカルマシンからではまず不十分なので、EC2で実施するための簡単な手順を記録します。
- AWS EC2で実施しましたが、他のクラウドのVMでも使えると思います。
なお、「JMeterって何?」という方は参考記事一覧から読むことをお勧めします。
JMeterとは
Apache謹製のLoad testing tool。HTTPなどのプロトコルで、Web上のサービスに対して負荷テストを実行するのが目的。負荷テストの詳細は.jmxファイル形式で管理され、テストのポータビリティが担保されている(嬉しい)。
メリット
- GUIが優れていて直感的にload testsを作れる
- GUIからもテストが実行可能で、テスト結果がグラフィカルに見られる
デメリット
- マルチノードの分散テストは管理が難しい
- GUIからではきちんと負荷テストを行えない
- その他あれば書いていきましょう
(余談)
一点目は結構致命的です。例えばこちらで指摘されているような超高負荷かつ地理的にも分散的なアクセスは、1つのノードからではほぼ再現不可能です。例えば、最高水準のEC2インスタンスr7iz.32xlargeでも、128vCPUsなので、128スレッドしかサポートできません。一方で、c5d.xlargeでも100台並列できれば400vCPUsです。
EC2でJMeterを実行しよう
実際にEC2でJMeterを実行する手順です。
インスタンス情報
c5a.24xlarge(96vCPUs, 192GiB) Spot instance
Ubuntu 22.04 LTS
単に試したいだけならここまでのインスタンスは必要ありません。しかし、JMeterはマルチスレッド実行なので、しっかり負荷をかけるには相応のvCPUsがあったほうが恩恵に預かりやすいです。
現状(2024年2月)、このインスタンスだとオンデマンドで 4ドル/h、スポットインスタンスで1~2ドル/h程度です。よーしテストするためにインスタンス立ち上げちゃうぞ〜!っていう前に、テスト内容と手順はしっかり定めておきたいなと思うプライシング帯ですね。第7世代のほうが安いんですが、人気ゆえかスポットリクエストだと私のリージョン(us-east-2)ではあまり手に入りませんでした。
※私だけかもしれませんが、AWSのService Quotaで、# max vCPUsが初期だと32になってるかもしれません。以下2個のどちらかで解決できます。
- Spot instanceの# max vCPUsを96に上げて、spot instance requestをする。
- オンデマンドインスタンスの# max vCPUsを96に上げて、オンデマンドインスタンスを起動する。
1はリクエストすればすぐできます。2はリクエストしても24時間程度時間がかかりそうです。
実行環境の整備
JMeterはjavaがインストールされていればどこでも実行できます。端的に言えば必要なのは3つだけです。
- JDK
- JMeterの実行ファイル等(後述しますがwgetできます)
- テスト情報の記載されたjmxファイル
なお、
$ sudo apt install jmeter
これでもインストールできるという記事もありましたが、私はこれではうまくいきませんでした。(理由を知っている方がいれば教えてください)
上記1〜3を実行するコマンドが以下です。
まずはEC2インスタンスにsshで接続しましょう。
$ ssh -i (秘密鍵) ubuntu@YourServerIP
# aptのアップデート
$ sudo apt update
# JDKのインストール
$ sudo apt install openjdk-17-jre-headless
# JMeterプロジェクトの取得と解凍
$ wget https://dlcdn.apache.org//jmeter/binaries/apache-jmeter-5.6.3.tgz
$ tar vxzf apache-jmeter-5.6.3.tgz
これでリモートでの実行環境は整いました。なお、デフォルトではEC2ではGUIは使えないので、jmxファイルをGUIから作れる超便利機能は使えません。よって、jmxファイルはローカルで作ってscpやS3経由でEC2インスタンスに送り込みましょう。
ここでは、ローカルからscpで送信するスクリプトのみ記載します。行ったり来たりになってしまいますが、このコードはローカル実行です。
$ scp -i (秘密鍵) /path/to/your/jmxfile.jmx\
ubuntu@(YourServerIP):/home/ubuntu
JMeterの実行
リモートホストからJMeterを実行しましょう。Ubuntuなのでhome(~/home/ubuntu)にいる想定です。この時、
home/
└ ubuntu
├ apache-jmeter-5.6.3
| └ bin
| └ jmeter
└ jmxfile.jmx
というディレクトリ構成になっていることを想定しています。
以下のコマンドでjmeterテストを実行します。
# ログファイルなし最も単純版
$ apache-jmeter-5.6.3/bin/jmeter -n -t jmxfile.jmx
# ログの出力先を指定
$ apache-jmeter-5.6.3/bin/jmeter -n -t jmxfile.jmx -l log.jtl
実行結果は、jmxファイルに記載した通りに出力されます。EC2からローカルに戻したい時はまたscpやS3経由で戻すといいです。
scp -i (秘密鍵) ubuntu@YourServerIP:/home/ubuntu/(リザルトファイル名) /(ローカルホスト上のパス)
参考記事