Heim > Betrieb und Instandhaltung > Nginx > So konfigurieren Sie ab, um Stresstests für den Nginx-Server durchzuführen

So konfigurieren Sie ab, um Stresstests für den Nginx-Server durchzuführen

PHPz
Freigeben: 2023-05-17 16:40:51
nach vorne
818 Leute haben es durchsucht

ab ist ein Leistungstesttool für Apache. Sie können nur das ab-Tool installieren.

Ubuntu-Installation ab

apt-get install apache2-utils
Nach dem Login kopieren

Centos-Installation ab

yum install httpd-tools
Nach dem Login kopieren

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.

So konfigurieren Sie ab, um Stresstests für den Nginx-Server durchzuführen

Nach der Vorbereitung können wir es testen.

ab -kc 1000 -n 1000 http://localhost/ab.html
Nach dem Login kopieren

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
Nach dem Login kopieren
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)
Nach dem Login kopieren

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
Nach dem Login kopieren

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)
Nach dem Login kopieren

, 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)
Nach dem Login kopieren

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)
Nach dem Login kopieren

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

So konfigurieren Sie ab, um Stresstests für den Nginx-Server durchzuführen

Es scheint, dass ich es optimieren oder die Maschine wechseln muss.

Detaillierte Erläuterung der ab-Parameter

Für normale Tests verwenden Sie die Parameter -c -n, um die Aufgabe abzuschließenSo konfigurieren Sie ab, um Stresstests für den Nginx-Server durchzuführenFormat: ./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!

Verwandte Etiketten:
Quelle:yisu.com
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage