Apache Bench - Umgebung einrichten

In diesem Kapitel erfahren Sie, wie Sie Ihre Umgebung für Apache Bench auf Ihrem VPS einrichten.

System Anforderungen

  • Memory - 128 MB

  • Disk Space - Keine Mindestanforderung

  • Operating System - Keine Mindestanforderung

Apache Bench installieren

Apache Bench ist eine eigenständige Anwendung und hat keine Abhängigkeiten von der Installation des Apache-Webservers. Das Folgende ist ein zweistufiger Prozess zum Installieren von Apache Bench.

Step 1 - Aktualisieren Sie die Paketdatenbank.

# apt-get update

Bitte beachten Sie, dass das Symbol # vor einem Terminalbefehl bedeutet, dass der Root-Benutzer diesen Befehl ausgibt.

Step 2 - Installieren Sie das Apache2-Utils-Paket, um Zugriff auf Apache Bench zu erhalten.

# apt-get install apache2-utils

Apache Bench ist jetzt installiert. Wenn Sie eine Webanwendung testen möchten, die auf demselben VPS gehostet wird, reicht es aus, nur den Apache-Webserver zu installieren.

# apt-get install apache2

Als Apache-Dienstprogramm wird Apache Bench bei der Installation des Apache-Webservers automatisch installiert.

Überprüfen der Apache Bench-Installation

Lassen Sie uns nun sehen, wie Sie die Apache Bench-Installation überprüfen. Der folgende Code hilft bei der Überprüfung der Installation -

# ab -V

Output

This is ApacheBench, Version 2.3 <$Revision: 1604373 $>
Copyright 1996 Adam Twiss, Zeus Technology Ltd, http://www.zeustech.net/
Licensed to The Apache Software Foundation, http://www.apache.org/

Wenn Sie die obige Terminalausgabe sehen, bedeutet dies, dass Sie Apache Bench erfolgreich installiert haben.

Erstellen eines privilegierten Sudo-Benutzers

Unter Sicherheitsgesichtspunkten wird es für Systemadministratoren als bewährte Methode angesehen, einen Sudo-Benutzer zu erstellen, anstatt als Root zu arbeiten. Wir werden einen Testbenutzer namens test erstellen, um -

# useradd -m -d /home/test -g sudo test

Lassen Sie uns das Passwort für den neuen Benutzer festlegen -

# passwd test

Das System fordert Sie zur Eingabe eines neuen Kennworts für den Benutzertest auf. Sie können ein einfaches Kennwort eingeben, da wir nur testen und nicht auf dem Produktionsserver bereitstellen. Normalerweise werden Sie vom Befehl sudo aufgefordert, das sudo-Benutzerkennwort einzugeben. Es wird empfohlen, kein kompliziertes Kennwort zu verwenden, da der Vorgang umständlich wird.

Output

Enter new UNIX password:
Retype new UNIX password:   
passwd: password updated successfully

Testen der Apache.org-Website

In diesem Abschnitt testen wir die Apache.org-Website. Wechseln wir zunächst zum sudo user test -

# su test

Zunächst werden wir die Website der Apache-Organisation testen. https://www.apache.org/. Wir werden zuerst den Befehl ausführen und dann die Ausgabe verstehen -

$ ab -n 100 -c 10 https://www.apache.org/

Hier -nist die Anzahl der Anforderungen, die für die Benchmarking-Sitzung ausgeführt werden müssen. Standardmäßig wird nur eine einzelne Anforderung ausgeführt, was normalerweise zu nicht repräsentativen Benchmarking-Ergebnissen führt.

Und -cist die Parallelität und gibt die Anzahl mehrerer Anforderungen an, die gleichzeitig ausgeführt werden sollen. Standard ist jeweils eine Anforderung.

In diesem Test sendet Apache Bench 100 Anfragen mit Parallelität 10 an den Apache-Organisationsserver.

Output

This is ApacheBench, Version 2.3 <$Revision: 1604373 $>
Copyright 1996 Adam Twiss, Zeus Technology Ltd, http://www.zeustech.net/
Licensed to The Apache Software Foundation, http://www.apache.org/

Benchmarking www.apache.org (be patient).....done

Server Software:        Apache/2.4.7
Server Hostname:        www.apache.org
Server Port:            443
SSL/TLS Protocol:       TLSv1.2,ECDHE-RSA-AES256-GCM-SHA384,2048,256

Document Path:          /
Document Length:        58769 bytes

Concurrency Level:      10
Time taken for tests:   1.004 seconds
Complete requests:      100
Failed requests:        0
Total transferred:      5911100 bytes
HTML transferred:       5876900 bytes
Requests per second:    99.56 [#/sec] (mean)
Time per request:       100.444 [ms] (mean)
Time per request:       10.044 [ms] (mean, across all concurrent requests)
Transfer rate:          5747.06 [Kbytes/sec] received

Connection Times (ms)
              min  mean[+/-sd] median   max
Connect:       39   46  30.9     41     263
Processing:    37   40  21.7     38     255
Waiting:       12   15  21.7     13     230
Total:         77   86  37.5     79     301

Percentage of the requests served within a certain time (ms)
  50%     79
  66%     79
  75%     80
  80%     80
  90%     82
  95%     84
  98%    296
  99%    301
 100%    301 (longest request)

Nachdem Sie unseren ersten Test ausgeführt haben, ist das Verwendungsmuster für diesen Befehl wie folgt leicht zu erkennen:

# ab [options .....]  URL

wo,

  • ab - Apache Bench Befehl

  • options - Flags für eine bestimmte Aufgabe, die wir ausführen möchten

  • URL - Pfad-URL, die wir testen möchten

Grundlegendes zu den Ausgabewerten

Wir müssen die verschiedenen Metriken verstehen, um die verschiedenen von ab zurückgegebenen Ausgabewerte zu verstehen. Hier geht die Liste -

  • Server Software - Dies ist der Name des Webservers, der im HTTP-Header der ersten erfolgreichen Rückgabe zurückgegeben wird.

  • Server Hostname - Dies ist die in der Befehlszeile angegebene DNS- oder IP-Adresse.

  • Server Port- Dies ist der Port, an den ab angeschlossen ist. Wenn in der Befehlszeile kein Port angegeben ist, wird standardmäßig 80 für http und 443 für https verwendet.

  • SSL/TLS Protocol- Dies ist der Protokollparameter, der zwischen Client und Server ausgehandelt wird. Dies wird nur gedruckt, wenn SSL verwendet wird.

  • Document Path - Dies ist der Anforderungs-URI, der aus der Befehlszeilenzeichenfolge analysiert wird.

  • Document Length- Dies ist die Größe des ersten erfolgreich zurückgegebenen Dokuments in Byte. Wenn sich die Dokumentlänge während des Tests ändert, wird die Antwort als Fehler betrachtet.

  • Concurrency Level - Dies ist die Anzahl der gleichzeitigen Clients (entspricht Webbrowsern), die während des Tests verwendet werden.

  • Time Taken for Tests - Dies ist die Zeit, die vom Herstellen der ersten Socket-Verbindung bis zum Empfang der letzten Antwort benötigt wird.

  • Complete Requests - Die Anzahl der erfolgreichen Antworten.

  • Failed Requests- Die Anzahl der Anfragen, die als fehlgeschlagen angesehen wurden. Wenn die Anzahl größer als Null ist, wird eine weitere Zeile gedruckt, in der die Anzahl der Anforderungen angegeben ist, die aufgrund von Verbindung, Lesen, falscher Inhaltslänge oder Ausnahmen fehlgeschlagen sind.

  • Total Transferred- Die Gesamtzahl der vom Server empfangenen Bytes. Diese Anzahl ist im Wesentlichen die Anzahl der über die Leitung gesendeten Bytes.

  • HTML Transferred- Die Gesamtzahl der vom Server empfangenen Dokumentbytes. Diese Zahl schließt in HTTP-Headern empfangene Bytes aus

  • Requests per second- Dies ist die Anzahl der Anfragen pro Sekunde. Dieser Wert ergibt sich aus der Division der Anzahl der Anforderungen durch die Gesamtzeit.

  • Time per request- Die durchschnittliche Zeit pro Anfrage. Der erste Wert wird mit der Formel Parallelität * Zeitplan * 1000 / erledigt berechnet, während der zweite Wert mit der Formel Zeitplan * 1000 / erledigt berechnet wird

  • Transfer rate - Die Übertragungsrate, berechnet nach der Formel totalread / 1024 / timetaken.

Schnelle Analyse der Lasttestleistung

Nachdem wir die Überschriften der Ausgabewerte aus dem Befehl ab kennengelernt haben, versuchen wir, die Ausgabewerte für unseren ersten Test zu analysieren und zu verstehen.

  • Die Apache-Organisation verwendet ihre eigene Webserver-Software - Apache (Version 2.4.7).

  • Der Server überwacht Port 443 aufgrund von https. Wäre es http gewesen, wäre es 80 gewesen (Standard).

  • Die insgesamt übertragenen Daten betragen 58769 Byte für 100 Anforderungen.

  • Test in 1.004 Sekunden abgeschlossen. Es gibt keine fehlgeschlagenen Anforderungen.

  • Anfragen pro Sekunde - 99,56. Dies wird als ziemlich gute Zahl angesehen.

  • Zeit pro Anfrage - 100,444 ms (für 10 gleichzeitige Anfragen). Über alle Anforderungen hinweg beträgt sie also 100,444 ms / 10 = 10,044 ms.

  • Übertragungsrate - 1338,39 [KB / s] empfangen.

  • In der Verbindungszeitstatistik können Sie feststellen, dass viele Anforderungen einige Sekunden warten mussten. Dies kann daran liegen, dass der Apache-Webserver Anforderungen in die Warteschlange stellt.

In unserem ersten Test hatten wir eine Anwendung (dh www.apache.org) getestet, die auf einem anderen Server gehostet wurde. Im späteren Teil des Tutorials werden wir unsere Beispiel-Webanwendungen testen, die auf demselben Server gehostet werden, von dem aus wir die ab-Tests ausführen werden. Dies dient der Erleichterung des Lernens und der Demonstration. Idealerweise sollten sich der Hostknoten und der Testknoten für eine genaue Messung unterscheiden.

Um ab besser zu lernen, sollten Sie vergleichen und beobachten, wie sich die Ausgabewerte für verschiedene Fälle ändern, während wir in diesem Lernprogramm fortfahren.

Zeichnen der Ausgabe von Apache Bench

Hier werden wir das relevante Ergebnis darstellen, um zu sehen, wie viel Zeit der Server benötigt, wenn die Anzahl der Anforderungen zunimmt. Dafür werden wir die hinzufügen-g Option im vorherigen Befehl, gefolgt vom Dateinamen (hier out.data), in dem die ab-Ausgabedaten gespeichert werden -

$ ab -n 100 -c 10 -g out.data https://www.apache.org/

Lassen Sie uns jetzt die sehen out.data bevor wir eine Handlung erstellen -

$ less out.data

Output

starttime       seconds ctime   dtime   ttime   wait
Tue May 30 12:11:37 2017        1496160697      40      38      77      13
Tue May 30 12:11:37 2017        1496160697      42      38      79      13
Tue May 30 12:11:37 2017        1496160697      41      38      80      13
...

Lassen Sie uns nun die Spaltenüberschriften in der out.data Datei -

  • starttime - Dies ist das Datum und die Uhrzeit, zu der der Anruf gestartet wurde.

  • seconds - Wie Startzeit, jedoch im Unix-Zeitstempelformat (Datum -d @ 1496160697 gibt die Startzeitausgabe zurück).

  • ctime - Dies ist die Verbindungszeit.

  • dtime - Dies ist die Bearbeitungszeit.

  • ttime - Dies ist die Gesamtzeit (es ist die Summe von ctime und dtime, mathematisch ttime = ctime + dtime).

  • wait - Dies ist die Wartezeit.

Schauen Sie sich das folgende Bild an, um eine bildliche Darstellung der Beziehung zwischen diesen mehreren Elementen zu erhalten:

Wenn wir über ein Terminal arbeiten oder wenn keine Grafiken verfügbar sind, gnuplotist eine gute Option. Wir werden es schnell verstehen, indem wir die folgenden Schritte ausführen.

Lassen Sie uns gnuplot installieren und starten -

$ sudo apt-get install gnuplot  
$ gnuplot

Output

G N U P L O T
Version 4.6 patchlevel 6    last modified September 2014
Build System: Linux x86_64

Copyright (C) 1986-1993, 1998, 2004, 2007-2014
Thomas Williams, Colin Kelley and many others

gnuplot home:     http://www.gnuplot.info
faq, bugs, etc:   type "help FAQ"
immediate help:   type "help"  (plot window: hit 'h')

Terminal type set to 'qt'
gnuplot>

Da wir über das Terminal arbeiten und davon ausgehen, dass keine Grafiken verfügbar sind, können wir das dumme Terminal auswählen, das die Ausgabe in ASCII über das Terminal selbst ausgibt. Dies hilft uns, eine Vorstellung davon zu bekommen, wie unser Plot mit diesem schnellen Tool aussieht. Bereiten wir nun das Terminal für den ASCII-Plot vor.

gnuplot> set terminal dumb

Output

Terminal type set to 'dumb'
Options are 'feed  size 79, 24'

Da unser Gnuplot-Terminal jetzt für den ASCII-Plot bereit ist, zeichnen wir die Daten aus dem out.data Datei -

gnuplot> plot "out.data" using 9  w l

Output

1400 ++-----+------+-----+------+------+------+------+-----+------+-----++
       +      +      +     +      +      +      +"out.data" using 9 ****** +
       |                                                                   |
  1200 ++                       ********************************************
       |     *******************                                           |
  1000 ++    *                                                            ++
       |     *                                                             |
       |     *                                                             |
   800 ++   *                                                             ++
       |    *                                                              |
       |    *                                                              |
   600 ++   *                                                             ++
       |    *                                                              |
       |    *                                                              |
   400 ++   *                                                             ++
       |    *                                                              |
   200 ++   *                                                             ++
       |    *                                                              |
       +****  +      +     +      +      +      +      +     +      +      +
     0 ++-----+------+-----+------+------+------+------+-----+------+-----++
       0      10     20    30     40     50     60     70    80     90    100

Wir haben die ttime, die Gesamtzeit (in ms) aus Spalte 9 in Bezug auf die Anzahl der Anforderungen aufgetragen. Wir können feststellen , dass für die ersten zehn Anfragen, die Gesamtzeit , in der fast 100 ms war, für die nächsten 30 - Anfragen (10 th bis 40 th ), es bis 1100 ms erhöht, und so weiter. Ihr Grundstück muss je nach Ihrem unterschiedlich seinout.data.