ホームページ  >  記事  >  バックエンド開発  >  ベンチマークツール:ab

ベンチマークツール:ab

WBOY
WBOYオリジナル
2016-07-23 08:54:451178ブラウズ
ベンチマーク テスト ツール (ab)

腹筋とは何ですか?
ab は、Windows および Linux プラットフォームで実行できるコマンドラインベースのツールです。
このツールを選んだ理由は何ですか?
使いやすく、いくつかのコマンドオプションを入力するだけで結果が得られ、インストールも簡単です。

アブをインストールする

win: ローカルに Apache 開発環境がある場合、ab はデフォルトで apache ディレクトリの下の bin ディレクトリにあります。bin ディレクトリを開くと表示されます
linux: httpd-tools を yum install してインストールするだけです

。 簡単に始められます

次のコードを直接入力します (ab が配置されているディレクトリを切り替えることに注意してください)
-c 10 は同時実行数が 10 であることを意味します
-n 10 は合計 100 回の訪問を意味します
訪問する URL が続きます。必須であることを忘れないでくださいhttp://

  1. D:phpStudyApachebin>ab -c 10 -n 1000 http://example.com/phpinfo.php
コードをコピーします

ab が自分で実行して、次の結果が表示されます

  1. #ab ツールの説明、バージョン番号に注意してください
  2. これは ApacheBench、バージョン 2.3 <$Revision: 1604373 $>
  3. Copyright 1996 Adam Twiss, Zeus Technology Ltd、http://www. zeustech.net/
  4. The Apache Software Foundation にライセンス供与、http://www.apache.org/
  5. #テスト結果、合計 1000 件のテスト、アクセスの進行状況は 100 回ごとに表示されます、アクセスした Web サイトは example.com です
  6. ベンチマーク example.com (しばらくお待ちください)
  7. 100 リクエストを完了
  8. 200 リクエストを完了
  9. 300 リクエストを完了
  10. 500 リクエストを完了
  11. 600 リクエストを完了
  12. 700 リクエストを完了
  13. 800 リクエストを完了
  14. 900 リクエストを完了
  15. 完了リクエスト1000件
  16. 1000 件のリクエストを完了しました
  17. #サーバー情報
  18. サーバー ソフトウェア: nginx/1.6.2 #サーバー Web ソフトウェア
  19. サーバー ホスト名: example.com #ホスト アドレス
  20. サーバー ポート: 80 #アクセス ポート
  21. #ドキュメント情報
  22. ドキュメント パス: /phpinfo .php #アクセスされたドキュメント
  23. ドキュメントの長さ: 94804 バイト #結果サイズのバイト数を返します(html、js、css、画像、応答のすべてのコンテンツの合計バイト数を含む)
  24. #リンク情報
  25. 同時実行レベル: 10 #同時実行数、-c 10 セット 10 個の同時実行
  26. テストにかかった時間: 7.498 秒 #合計所要時間、単位は秒
  27. 完了したリクエスト: 1000 # 総リクエストのうち完了したリクエストの合計数
  28. 失敗したリクエスト: 219 #失敗したリクエストの合計数
  29. (接続: 0、受信: 0、長さ: 219、例外: 0)
  30. 非 2xx 応答: 9 #2xx シリーズで成功したリクエストの合計数受信
  31. 転送合計: 94135779 バイト # ヘッダー情報を含むリクエストの合計数における応答距離の合計のサイズ バイト
  32. 転送された HTML: 93952076 バイト # リクエストの合計数におけるテキスト コンテンツの合計サイズ バイト
  33. Requests 1 秒あたり: 133.36 [#/秒] (平均) #1 秒あたりにサポートされる同時実行数。ここでは 1 秒あたり 133.36 同時実行がサポートされます
  34. リクエストあたりの時間: 74.984 [ms] (平均) #リクエストを完了するのにかかる合計時間
  35. リクエストあたりの時間: 7.498 [ms] (すべての同時リクエストの平均) #すべての同時リクエストのうち、1 つのリクエストを完了するのにかかる合計時間
  36. 転送速度: 12259.83 [Kbytes/sec] 受信 #1 秒あたりの合計受信バイト数(KB)
  37. #テスト時間結果データ、合計項目に注目してください。同時実行数10の場合、リクエスト完了までの最小時間(min) 9ミリ秒、最大消費時間(max) 146ミリ秒
  38. 接続時間( ms)
  39. 最小平均[+/-SD]中央値最大
  40. 接続: 0 0 0.7 0 20
  41. 処理中: 9 74 22.2 68 146
  42. 待機中: 6 73 22.1 67 143
  43. 合計: 9 74 22.2 68 146
  44. #パーセンテージのたとえば、最初の項目の 50% 68 は、リクエストの半分が 68 ミリ秒以内に完了したことを意味し、95% 129 は、1,000 件のリクエストのうち、100% 98 件のリクエストが 129 ミリ秒以内に完了したことを意味します
  45. パーセンテージ特定の時間内に処理されたリクエスト (ミリ秒)
  46. 50% 68
  47. 66% 78
  48. 75% 86
  49. 80% 92
  50. 90% 109
  51. 95% 122
  52. 98% 129
  53. 99% 133
  54. 100% 146 (最長リクエスト) )
コードをコピーab オプション
次のコマンドを入力して、コマンド オプションの使用法と意味をそれぞれ説明する ab ヘルプ ドキュメントを取得します

    D:phpStudyApachebin>ab -h
コードをコピーします

ab帮ヘルプ文の出力

  1. 使用法: ab [オプション] [http://]ホスト名[:ポート]/パス
  2. オプションは次のとおりです:
  3. -n リクエスト 実行するリクエストの数
  4. -c 同時実行数
  5. 一度に行うリクエスト
  6. -t timelimit 秒から最大まで。ベンチマークに費やすため
  7. これは、 -n 50000
  8. -s timeout を意味します。各応答を待ちます
  9. デフォルトは 30 秒です
  10. -b windowsize TCP 送受信バッファのサイズ (バイト単位)
  11. -B address 送信接続を行うときにバインドするアドレスです
  12. -p postfile POST するデータを含むファイル。 -T
  13. -u putfile データを含むファイルを PUT に設定することも忘れないでください。 -T
  14. -T content-type POST/PUT データに使用するコンテンツ タイプ ヘッダーも忘れずに設定してください。例:
  15. 'application/x-www-form-urlencoded'
  16. デフォルトは 'text/plain' です
  17. -v verbosity印刷するトラブルシューティング情報の量
  18. -w 結果を HTML テーブルに出力します
  19. -i GET の代わりに HEAD を使用します
  20. -x 属性 テーブル属性として挿入する文字列
  21. -y 属性 tr 属性として挿入する文字列
  22. -z 属性 挿入する文字列td または th 属性として
  23. -C 属性 Cookie を追加します。 「アパッチ=1234」。 (反復可能)
  24. -H 属性 任意のヘッダー行を追加します。 'Accept-Encoding: gzip'
  25. すべての通常のヘッダー行の後に挿入されます。 (反復可能)
  26. -A 属性 基本 WWW 認証を追加します。属性
  27. はコロンで区切られたユーザー名とパスワードです。
  28. -P 属性 基本プロキシ認証を追加します。属性
  29. はコロンで区切られたユーザー名とパスワードです。
  30. -X proxy:port Proxyserverおよび使用するポート番号を表示します
  31. -V バージョン番号を出力して終了します
  32. -k HTTP KeepAlive 機能を使用します
  33. -d 提供されたテーブルのパーセンタイルを表示しません。
  34. -S 信頼性推定値と警告を表示しません。
  35. -q 実行中に進行状況を表示しません。 150 を超えるリクエスト
  36. -l 可変ドキュメント長を受け入れます (動的ページに使用します)
  37. -g filename 収集したデータを gnuplot 形式のファイルに出力します。
  38. -e filename 提供されたパーセンテージを含む CSV ファイルを出力します
  39. -r ソケットで終了しませんエラーを受信します。
  40. -m メソッド メソッド名
-h 使用法情報 (このメッセージ) を表示します
复制代码

英文看不懂,附上中文解释,网上抄的,我没试过
  1. -n 即時リクエスト、圧力測定の同時実行回数を指定します。
  2. -c 即時同時実行数、圧力測定の同時実行数を指定します。
  3. -t 即時制限、待機の最大時間 (単位:秒)。
  4. -b
  5. -p 略 postfile、POST リクエスト送信時に上流のファイルが必要なため、さらに -T パラメータを設定する必要があります。
  6. -u 略 putfile、PUT リクエスト送信時
  7. -T は content-type を表し、Content-Type 要求情報を設定するために使用されます。例: application/x-www-form-urlencoded、値は text/plain です。
  8. -v は、印刷補助情報の冗長性を指定します。
  9. -w HTML テーブル形式で結果を印刷します。
  10. -i GET 要求の代わりに HEAD 要求を使用します。
  11. -x 入力文字列はテーブルのプロパティとして機能します。
  12. -y入力文字列は tr のプロパティとして機能します。
  13. -z 入力文字列は td のプロパティとして機能します。
  14. -C Cookie 情報を追加します。例: "Apache=1234" (このパラメータ選択を繰り返して複数追加することができます)。
  15. -H任意のリクエストを追加します。例: "Accept-Encoding: gzip"。リクエストは、存在する複数のリクエストの後に追加されます (このパラメータ選択を繰り返して複数を追加できます)。
  16. -P は、使用するプロキシ サーバーとポートを指定します。例: "126.10.10.3:88"。
  17. -V バージョン番号を印刷して終了します。
  18. -k HTTP の KeepAlive 特性を使用します。
  19. -k HTTP の KeepAlive 特性を使用します。
  20. -d 百分率を表示しません。
  21. -S 事前転送と警告メッセージ。
  22. -g は、結果情報を gnuplot 形式のファイルに出力します。
  23. -e は、結果情報を CSV 形式のファイルに出力します。
  24. -r は、セキュリティメッセージを受信したときにプログラムを終了しないように指定します。
复制コード

通常は -n、-c、-t を使用します
-n リクエストの合計数
-c 同時実行数
-t 指定された秒数内の同時実行数

-t の使用法についてお話します。以下は 20 秒間に 10 件の同時アクセスを意味します

    D:phpStudyApachebin> http://example.com/phpinfo.php
  1. ApacheBench、バージョン 2.3
  2. 著作権 1996 Adam Twiss、Zeus Technology Ltd、http://www.zeustech.net/
  3. Apache Software Foundation、http://www.apache org にライセンス供与。 /
  4. example.com のベンチマーク (しばらくお待ちください)
  5. 3011 件のリクエストを完了しました
  6. サーバー ソフトウェア: nginx/1.6.2
  7. サーバー ホスト名: example.com
  8. サーバー ポート: 80
  9. ドキュメント パス: /phpinfo.php
  10. ドキュメントの長さ: 94804 バイト
  11. 同時実行レベル: 10
  12. テストにかかった時間: 20.006 秒
  13. 完了したリクエスト: 3011
  14. 失敗したリクエスト: 495
  15. (接続: 0、受信: 0、長さ: 495、例外: 0)
  16. 2xx 以外の応答: 54
  17. 合計転送数: 280896464 バイト
  18. 転送された HTML: 280344222 バイト
  19. 1 秒あたりのリクエスト数: 150.50 [#/sec] (平均)
  20. リクエストあたりの時間: 66.444 [ms] (平均)
  21. リクエストあたりの時間: 6.644 [ms] (すべての同時リクエストの平均)
  22. 転送速度: 13711.44 [Kbytes/sec] 受信
  23. 接続時間 (ms)
  24. 最小平均[+/-SD] 中央値最大
  25. 接続: 0 0 0.5 0 10
  26. 処理: 6 66 17.6 63 203
  27. 待機中: 5 64 17.3 61 202
  28. 合計: 6 66 17.6 63 203 % 75
  29. 90% 82
  30. 95% 92
  31. 98% 113
  32. 99% 125
  33. 100% 203 (最長リクエスト)
  34. コードをコピー
  35. 特記事項: http://www.example.com/ にアクセスした場合、特定のファイルはありません。最後の / を忘れずに追加してください。 ! !そうしないと、アクセスできなくなる可能性があります。 ! !
  36. ベンチマークテストに影響を与える可能性のある状況
位置情報とネットワークの問題
応答ファイルのサイズ
コードの複雑さ

ブラウザ解析

Webサーバーの構成

位置情報とネットワークの問題

Webサーバーが海外にある場合は、ご想像のとおり、ルーターノード、サーバーノードを経由し、太平洋下の光ケーブルを経由してWebサーバーにアクセスします。 Web サーバーで処理した後、海底光ケーブルを使用して各サーバーとルーティング ノードに戻ります。これはテスト結果に間違いなく影響します (サーバー上で直接 ab テストを実行することをお勧めします)。 応答ファイルのサイズ

3 MB ページが送信される場合、サーバー ネットワーク カードは、送信プロセス中に 3 MB のデータを 1 つの小さなデータ パケットに分割します。1 つのデータ パケットだけが破損または紛失した場合は、すべてのデータ パケットが再送信されるため、送信されたパケットは再送信されます。小さいほど良いと同時に、データ転送量が小さいほど、ユーザーのマシンへの転送速度が速くなります。

コードの複雑さ

コードの複雑さは、ファイル呼び出し、データベースアクセス、リモートAPIインターフェース呼び出しなどだけでなく、ビジネスロジックの複雑な処理を意味し、処理時間に影響します

ブラウザの解析

各ブラウザには、js、css、html を処理する独自の方法があります。IE8 以下と chrome の違いについて考えてみましょう。 Webサーバーの設定

一般的な Web サーバーのインストール後、簡単な設定を使用して Web サービスを実装できますが、そのような設定では Web サーバーのパフォーマンスを最大化することはできません。パフォーマンスを最大化するためにサーバーを構成する必要があります。ここでは、シンプルで実用的なキープアライブ手順を示します。

キープアライブの機能は、Web サーバーが特定の数の接続を開き、これらの接続を開いたままにし、受信リクエストを迅速に処理できるようにすることで、受信リクエストごとに接続を開いてリクエストを処理することはありません。 , リクエストを処理するサーバー上のプロセスの数を減らすことで、同時実行数が増加します。

次の文

#-k など、テストには ab の -k を使用します。これにより、サーバーはオープンで許可された状態で 5 つの同時接続を保存でき、他のリクエストを迅速に処理できるようになり、処理が軽減されます。新しいリクエストを作成する時間

ab -c 5 -t 100 -k http://www.example.com/



コードをコピーします

  1. テストツール
声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。