質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

90.52%

  • Ruby on Rails 4

    2434questions

    Ruby on Rails4はRubyによって書かれたオープンソースのウェブフレームワークです。 Ruby on Railsは「設定より規約」の原則に従っており、効率的に作業を行うために再開発を行う必要をなくしてくれます。

  • AWS(Amazon Web Services)

    2000questions

    Amazon Web Services (AWS)は、仮想空間を機軸とした、クラスター状のコンピュータ・ネットワーク・データベース・ストーレッジ・サポートツールをAWSというインフラから提供する商用サービスです。

  • nginx

    837questions

    nginixは軽量で高性能なwebサーバーの1つです。BSD-likeライセンスのもとリリースされており、あわせてHTTPサーバ、リバースプロキシ、メールプロキシの機能も備えています。MacOSX、Windows、Linux、上で動作します。

  • unicorn

    98questions

    Unicornは、汎用のRackアプリケーションサーバ。RackとWebサーバーの機能を併せ持ちます。レスポンス処理や、Nginx単体がRackの機能をサポートしていない事から、一般的にはNginx+Unicorn+Railsの構成を取って用います。

  • JMeter

    35questions

    Apache JMeterとは、Webアプリケーションの負荷テストをするためのJavaアプリケーションです。

Jmeterによる負荷テスト。スループットが上がらない。

受付中

回答 3

投稿 編集

  • 評価
  • クリップ 1
  • VIEW 2,490

Aihara

score 16

負荷をかけるソフトはJmeter2.13を使っています。
サーバーの環境はAWSで構築しました。

アプリのAPIサーバーに対して負荷テストを行っているのですが
想定している負荷をかけることができず、困っております。
負荷リクエストはかけられているのですが、具体的な値として160req/sを上限に全く上がりません。

負荷をかける側のサーバーに対して
・台数を増やす
・性能を上げる
・リクエスト数を増やす
以上のことを行いましたがスループットは上がりません。
特にリクエスト数(スレッドグループとスレッド数とループ回数)を増やすと
エラーが多く出るようになってしまいます。(90%くらい)
現状は
それなのに負荷をかける側のサーバーのCPUの使用率は6%ほどで、
サーバーを限界まで使い切れていないようです。
受け手側のサーバーもCPU使用率が10%もいかないです。

サーバー環境

APIサーバーが2台あります。
インスタンスタイプはt2.xlargeです
Nginx*Uniconr*Railsで作りました。
ELBを通しており、Auto Scalingも設定しています。
Nginxでの設定で
worker_processes Auto
worker_connections 2048
worker_rlimit_nofile 4096
worker_cpu_affinity 1000 0100 0010 0001
と設定しました。

Unicornでは
worker_processes 10
と設定しました。

データベースはpsqlを使用しており
AWSのRDSで作成しました。
db.m4.largeを使用しています。

一方Jmeter側ですが
Masterが1台、Slaveが1台です。
インスタンスタイプはm4.xlargeです。
投げているリクエストはPOSTです。ファイルなどは送信していません。
情報量もユーザーIDと投稿のID、HEADERにAuthKeyを付与してるだけです。

*追記
APIサーバー及びJmeterのMasterおよびSlaveのサーバーは
どちらもAWSで、かつ同じVPS内に立てています。


Jmeterのファイル作成はローカルで行っています。こちらもバージョン2.13です。
HEAPのメモリを上げる作業をしてみましたが、変わりませんでした。

同時接続2000を目標に捌けるよう環境構築をしたいです。

今はJmeterのバージョンを最新にしてもう一度試してみよう、、、というところです。

何か不足している情報がございましたら追加致します。
何卒宜しくお願い致します。

  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

質問への追記・修正、ベストアンサー選択の依頼

  • t_obara

    2017/02/13 19:37

    サーバとjmeterの実行時の位置関係が不明確です。どちらもawsでしょうか?ネットワーク構成上で上限が設定されるようなことがないのであれば、jmeter側の設定に問題がありそうです。

    キャンセル

  • Aihara

    2017/02/13 19:46

    tomohiro_obara様、ご指摘ありがとうございます。追記いたしました。

    キャンセル

回答 3

+1

160req/sを上限に全く上がりません。

特にリクエスト数(スレッドグループとスレッド数とループ回数)を増やすと 
エラーが多く出るようになってしまいます。(90%くらい)

要するに、そのあたりにシステムとしての限界値があるということだと思います。
どこが限界になっているかは、提示された情報では不明です。
関係しているのが、提示されているもので全てなのであれば、ELB が怪しい気がしますがただの勘です。
丁寧に各関連箇所のログを確認することで、問題を特定できると思います。

少し気になったのですが、AWSって負荷テストすることを規約で制限していないですか?普通 IaaS , PaaS ベンダーはそのあたりを縛ってくるのですが。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

0

ELBはある程度継続的に負荷があがると自動的にスケールします。
digコマンドでELBのスケール状態を確認しましょう。
事前に負荷をかけること(暖機運転)を実施し、ELBがスケールしてから実際のテストを実施するといいかもしれません。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

0

Jmeter側が2台で160req/sしか出ない、とのことですが、これは1台でも同様の現象でしょうか?

以前、似たようなシチュエーションでJmeterを利用した際、1台あたりが負荷をかけられる上限が、100TPS前後だったため、1,000tps近くまで負荷をかけるときは、10台以上のJmeterから一気に負荷をかけたことがあります(構成は、1Master/9Slaveのような感じで)

つまり、Jmeter側が、あまり性能が出ないことで、負荷をかけ切れなかった、ということですね

これは、Jmeter内でBeanShellを利用しているときは、より顕著です

なお、スレッド数とループ回数をムダに増やしても、エラーになるだけなので、2~3分程度、流し続けてもエラーが出ないレベルを上限として、足りない場合は、台数追加でこなす、というのが確実でしょう

p.s.エラー無く、負荷を上げ続けられるようになると、「今度は負荷をかけ過ぎる」という状況が発生するため、一定のTPS以上に負荷をかけないよう、「定数スループットタイマー」で抑止してあげると、キレイに負荷をかけ続けられるようになります

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

15分調べてもわからないことは、teratailで質問しよう!

  • ただいまの回答率 90.52%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

  • 解決済

    JMeterの結果について

    お世話になります。 Webアプリの負荷テストをする際、apache.JMeterを使おうと思っています。 使い方を覚えている段階なのですが、設定と結果の見方で質問があります

  • 解決済

    JMeterで動的コンテンツのテスト方法

    お世話になります。 JMeterでJavaScriptを使った動的コンテンツ(画像など)の表示をテストする方法を探しています。 具体的には、 ページを表示するときに、

  • 受付中

    Webサーバのレスポンスタイムを調べたい

    Webサーバの前にロードバランサを置こうとしています。このロードバランサのタイムアウト時間を設定するにあたり、現在のWebサーバがどの程度のレスポンスタイムで応答しているのかを調査

  • 解決済

    Nginx+Node.jsの秒間アクセス数について

    AWSのEC2インスタンスにてNginx+Node.jsのサーバを作り色々試しているのですが、秒間のアクセス数500〜600くらいで限界がくるような感じです。 これはチューニング

  • 受付中

    nginxを起動したら、起動に失敗しました。

    nginxをインストールしたので、「systemctl start nginx.service」とコマンドを入力して起動させたら、 起動に失敗しましたとエラーが表示されました。

  • 解決済

    Node.jsが動くWebサーバ(Nginx)のスケールアップについて

    Nginx上で動くNode.jsアプリケーションを運用しようと考えています。 Node.jsはシングルスレッドで動作するということは、サーバのスケールアップによりCPUコア数

  • 解決済

    Mastodonインスタンスでデフォルトの画像が見つかりません

    先程の質問を〆切った後、マストドンのインスタンスを再構築したのですが、自分のサイトを開くと下の画像が出てきました。 nginxのエラーログは次の通りです。

  • 解決済

    EC2インスタンスのロードアベレージが急激に上がる

    EC2上で nginx + php-fpm 構成のWebサーバ(m3.medium) を2台ロードバランシングして運用しています。 ある時ロードアベレージが急上昇し、2台ともレスポ

同じタグがついた質問を見る

  • Ruby on Rails 4

    2434questions

    Ruby on Rails4はRubyによって書かれたオープンソースのウェブフレームワークです。 Ruby on Railsは「設定より規約」の原則に従っており、効率的に作業を行うために再開発を行う必要をなくしてくれます。

  • AWS(Amazon Web Services)

    2000questions

    Amazon Web Services (AWS)は、仮想空間を機軸とした、クラスター状のコンピュータ・ネットワーク・データベース・ストーレッジ・サポートツールをAWSというインフラから提供する商用サービスです。

  • nginx

    837questions

    nginixは軽量で高性能なwebサーバーの1つです。BSD-likeライセンスのもとリリースされており、あわせてHTTPサーバ、リバースプロキシ、メールプロキシの機能も備えています。MacOSX、Windows、Linux、上で動作します。

  • unicorn

    98questions

    Unicornは、汎用のRackアプリケーションサーバ。RackとWebサーバーの機能を併せ持ちます。レスポンス処理や、Nginx単体がRackの機能をサポートしていない事から、一般的にはNginx+Unicorn+Railsの構成を取って用います。

  • JMeter

    35questions

    Apache JMeterとは、Webアプリケーションの負荷テストをするためのJavaアプリケーションです。