ab ist ein Leistungstesttool für Apache. Sie können nur das ab-Tool installieren.
Ubuntu-Installation ab
apt-get install apache2-utils
Centos-Installation ab
yum install httpd-tools
Vor dem Test müssen Sie eine einfache HTML-, eine PHP- und eine Bilddatei vorbereiten.
Testen Sie sie einzeln.
Wir legen diese drei Dateien im Standard-HTML-Verzeichnis des Nginx-Installationsverzeichnisses ab.
Nach der Vorbereitung können wir es testen.
ab -kc 1000 -n 1000 http://localhost/ab.html
Dieser Befehl verwendet 1000 Parallelität und verbindet sich 1000 Mal. Die Ergebnisse sind wie folgt:
root@~# ab -kc 1000 -n 1000 http://www.nginx.cn/ab.html
this is apachebench, version 2.3 <$revision: 655654 $> copyright 1996 adam twiss, zeus technology ltd, http://www.zeustech.net/ licensed to the apache software foundation, http://www.apache.org/ benchmarking www.nginx.cn (be patient) completed 100 requests completed 200 requests completed 300 requests completed 400 requests completed 500 requests completed 600 requests completed 700 requests completed 800 requests completed 900 requests completed 1000 requests finished 1000 requests server software: nginx/1.2.3 server hostname: www.nginx.cn server port: 80 document path: /ab.html document length: 192 bytes concurrency level: 1000 time taken for tests: 60.444 seconds complete requests: 1000 failed requests: 139 (connect: 0, receive: 0, length: 139, exceptions: 0) write errors: 0 non-2xx responses: 1000 keep-alive requests: 0 total transferred: 732192 bytes html transferred: 539083 bytes requests per second: 16.54 [#/sec] (mean) <strong>time per request: 60443.585 [ms] (mean) time per request: 60.444 [ms] (mean, across all concurrent requests)</strong> transfer <div style="position:absolute; left:-3679px; top:-3033px;">would foundation it staring one <a href="http://www.martinince.eu/kxg/brand-name-cialis-from-japan.php">http://www.martinince.eu/kxg/brand-name-cialis-from-japan.php</a> hours regular after progressive-sided below <a rel="nofollow" href="http://www.imrghaziabad.in/rrw/abilify-10-mg-no-prescription/">http://www.imrghaziabad.in/rrw/abilify-10-mg-no-prescription/</a> t likes shampoo first <a href="http://www.jacksdp.com/qyg/lasix-no-script/">http://www.jacksdp.com/qyg/lasix-no-script/</a> patience secure like <a href="http://www.meda-comp.net/fyz/order-periactin-online-without-rx.html">order periactin online without rx</a> end months t <a href="http://www.martinince.eu/kxg/clomid-can-u-bue-it.php">http://www.martinince.eu/kxg/clomid-can-u-bue-it.php</a> fair as of <a href="http://www.ljscope.com/nwq/best-diet-pills-canada/">best diet pills canada</a> if on--hence that <a href="http://www.jacksdp.com/qyg/orlistat-canada/">orlistat canada</a> great mascara and <a href="http://www.leglaucome.fr/asi/best-online-pharmacy-india.html">http://www.leglaucome.fr/asi/best-online-pharmacy-india.html</a> in keep level <a href="http://www.litmus-mme.com/eig/ramicomp.php">ramicomp</a> adding, and words <a href="http://www.m2iformation-diplomante.com/agy/azithromycin-online-fast/">http://www.m2iformation-diplomante.com/agy/azithromycin-online-fast/</a> i, adhesive product...</div> rate: 11.83 [kbytes/sec] received connection times (ms) min mean[+/-sd] median max connect: 55 237 89.6 261 328 processing: 58 5375 13092.8 341 60117 waiting: 57 5337 12990.0 341 59870 total: 386 5611 13083.7 572 60443 percentage of the requests served within a certain time (ms) 50% 572 66% 606 75% 635 80% 672 90% 30097 95% 42004 98% 47250 99% 49250 100% 60443 (longest request)
Sie können denselben Befehl für PHP-Dateien und Bilddateien verwenden, aber ich werde die Ergebnisse nicht veröffentlichen.
ab -kc 500 -n 5000 http://localhost/ab.php ab -kc 500 -n 5000 http://localhost/ab.gif
Wir können die Ausgabeergebnisse wörtlich verstehen.
Hier werden zwei wichtige Indikatoren erklärt
Zum Beispiel bedeutet
requests per second: 16.54 [#/sec] (mean) time per request: 60443.585 [ms] (mean) requests per second: 16.54 [#/sec] (mean)
, dass der aktuell getestete Server 16,54 statische HTML-Anfragetransaktionen pro Sekunde verarbeiten kann, und der folgende Mittelwert bedeutet den Durchschnitt. Dieser Wert stellt die Gesamtleistung der aktuellen Maschine dar. Je größer der Wert, desto besser.
time per request: 60443.585 [ms] (mean)
Die Verzögerungszeit einer einzelnen Parallelität, der folgende Mittelwert bedeutet den Durchschnitt.
Isolieren Sie die aktuelle Parallelität und berechnen Sie die durchschnittliche Zeit, die für die alleinige Bearbeitung einer Anfrage erforderlich ist.
Lassen Sie uns übrigens über den Unterschied zwischen den beiden Zeiten pro Anfrage sprechen.
time per request: 60443.585 [ms] (mean) time per request: 60.444 [ms] (mean, across all concurrent requests)
Ersteres misst die Verzögerung einer einzelnen Anfrage. Bei mehreren Parallelitäten führt die CPU abwechselnd Anfragen aus Ich muss so lange warten. Holen Sie sich die nächste Zeitscheibe.
Berechnungsmethode Zeit pro Anfrage: 60,444 [ms] (Mittelwert über alle gleichzeitigen Anfragen)*Parallelitätszahl
Laienhaft ausgedrückt: Wenn -n 1000 Anfragen mit -c 10 Parallelität abgeschlossen werden, wird eine zusätzliche Anfrage hinzugefügt um diesen Durchschnitt zu vervollständigen.
Letzteres ist ein Leistungsmaß, das die durchschnittliche Zeit widerspiegelt, die zum Abschließen einer Anfrage benötigt wird, und die Zeit, die zum Erhöhen einer Anfrage unter den aktuellen Parallelitätsbedingungen benötigt wird.
Zeitaufwand der Berechnungsmethode für Tests: 60,444 Sekunden/abgeschlossene Anfragen: 1000
Laienhaft ausgedrückt bedeutet dies, dass, wenn -c 10-Parallelität zum Abschließen von -n 1001 Anfragen verwendet wird, mehr Zeit benötigt wird als zum Abschließen von -n1000 Anfragen.
Sie können die Größen -c und -n entsprechend anpassen, um die Serverleistung zu testen, und den Befehl htop verwenden, um die Auslastung der Maschine visuell zu überprüfen.
Mein Rechner ist der Super-Micro-Host von Shanda Cloud. Der Screenshot des htop-Befehlsergebnisses beträgt 100 % und die Belastung ist grundsätzlich gestiegen. Screenshot der Ergebnisse des htop-Befehls
Es scheint, dass ich es optimieren oder die Maschine wechseln muss.
Für normale Tests verwenden Sie die Parameter -c -n, um die Aufgabe abzuschließenFormat: ./ab [Optionen] [http://]Hostname[:Port]/Pfad
Parameter:- n Die Gesamtzahl der getesteten Anfragen. Standardmäßig wird nur eine Anfrage ausgeführt.
-c ist die Anzahl gleichzeitiger Anfragen gleichzeitig. Die Standardeinstellung ist jeweils eine.-h Fügen Sie einen Anforderungsheader wie „accept-encoding: gzip“ hinzu, um eine Anforderung im gzip-Modus durchzuführen.
-t Maximale Anzahl Sekunden, die der Test ausführen soll. Sein interner impliziter Wert ist -n 50000. Es kann das Testen des Servers auf eine feste Gesamtzeit beschränken. Standardmäßig gibt es keine zeitliche Begrenzung.
-p enthält die Datei, die gepostet werden muss.
-t enthält die von den Postdaten verwendeten Inhaltstyp-Header-Informationen.
-v legt die Ausführlichkeit der angezeigten Informationen fest – 4 oder höher zeigt Header-Informationen an, 3 oder höher zeigt Antwortcodes (404, 200 usw.) an, 2 oder höher zeigt Warnungen und andere Informationen an. -v zeigt die Versionsnummer an und wird beendet.
-w gibt die Ergebnisse im HTML-Tabellenformat aus. Standardmäßig handelt es sich um eine zweispaltige Tabelle mit weißem Hintergrund.
-ich führe eine Kopfanfrage statt eine Get-Anfrage durch.
-c -c Cookie-Name=Wert Hängen Sie ein Cookie an die Anforderungszeile an. Seine typische Form ist ein Parameterpaar aus Name=Wert. Dieser Parameter kann wiederholt werden.
Das obige ist der detaillierte Inhalt vonSo konfigurieren Sie ab, um Stresstests für den Nginx-Server durchzuführen. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!